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第 工 f 元 


PHPMyAdmin 平台 的 配置 与 应 用 


数据 库 管理 系统 作为 操纵 数据 库 的 软件 ,是 网 络 应 用 、 信 息 管 理 和 办 公 自 动 化 等 软件 
的 核心 。MySQL 是 一 种 关系 数据 库 管 理 系 统 , 可 以 通过 结构 查询 语言 (Structured 
Query Language,SQL) 和 可 视 化 管理 工具 管理 数据 库 。 

PHPMyAdmin 是 以 PHP 为 基础 ,通过 Web 方式 架构 在 网 站 服务 器 上 运行 的 MySQL 
数据 库 管 理工 具 , 可 以 通过 浏览 器 远程 管理 MySQL 数据 库 , 方 便 数据 库 维护 。 
PHPMyAdmin 作为 MySQL 的 常用 管理 工具 需要 Web 服务 器 的 支持 才能 使 用 ,可 以 通过 
XAMPP(Apache 十 MySQL 二 PHP 十 PERL) 集 成 软件 包 统 一 安装 。 

本 单元 以 人 才 招 聘 网 站 为 例 , 采 用 XAMPP 集成 软件 包 搭建 MySQL 和 PHPMyAdmin 
运行 环境 ,通过 用 户 规划 数据库 设计 和 维护 等 操作 ,掌握 PHPMyAdmin 的 数据 库 管 理 
方法 。 


1.1 安装 和 配置 MySQL 环境 


一 、 实 验 目的 


通过 XAMPP 集成 软件 包 的 下 载 .安装 和 配置 等 操作 ,掌握 搭建 MySQL 数据 库 操作 
环境 和 使 用 PHPMyAdmin 数据 库 管理 工具 配置 数据 库 环境 的 方法 。 


二 、 实 验 任务 


(1) 下 载 并 安装 XAMPP 集成 软件 包 。 
(2) 使 用 PHPMyAdmin 配置 MySQL 数据 库 环境 。 


三 、 任 务 分 析 


搭建 MySQL 数据 库 应 用 环境 并 使 用 PHPMyAdmin 实现 数据 管理 涉及 多 个 软件 工 
,需要 分 别 下 载 .安装 并 修改 配置 文件 才能 使 用 。 用 XAMPP 集成 软件 包 可 以 简化 搭建 





过 程 ,安装 成 功 后 ,进行 简单 配置 即 可 正常 运行 ,适合 网 站 设计 的 初学 者 。 
、 预 备 知识 


1. XAMPP 集成 软件 包 


XAMPP 集成 软件 包 是 一 个 用 于 建设 动态 网 站 的 集成 软件 包 , 包 括 Apache 网 页 服务 
器 、MySQL 数据 库 服 务 器 、PHPMyAdmin 数据 库 管理 工具 、FileZilla 文件 传输 工具 、 
Mercury 邮件 传输 系统 和 TomCat 应 用 服务 器 等 多 个 实现 完整 网 站 功能 的 软件 模块 , 通 
过 XAMPP 可 以 统一 下 载 . 安 装 及 配置 文件 设置 ,简化 了 各 个 软件 的 安装 和 配置 过 程 。 


2. XAMPP 控制 面板 


为 了 统一 管理 软件 模块 ,XAMPP 集成 了 控制 面板 (Control Panel)。 通 过 控制 面板 ,可 
以 实现 相关 软件 模块 的 启动 .关闭 .配置 和 系统 功能 调用 等 操作 ,控制 面板 如 图 1-1 所 示 。 


模块 进程 ID ”模块 端口 号 动作 按钮 组 系统 功能 按钮 





Porls) Actions 

































































2 一 Apache 5912 80.443 [Stop | [Admin | [Confg ] [Logs |] (= 岂 Shell 

国 Mysal 5488 3306 [Stop |[ Admin |[ Conig |[ Logs | [Explorer 
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54 [Apache] XAMPP Apache is already running on port 443 
5 Starting Check-Tiner 

Control Panel Ready 

Attempting to start MySQL app... 

Status change detected: ruming 

Attempting to start Wercury app... 

Status change detected: rurning 

Atteapting to stop Mercury (PID: 9152) 
Status change detected: stopped 
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图 1-1 XAMPP 控制 面板 


下 面 介绍 控制 面板 中 各 功能 。 

(1) 模块 服务 按钮 。 设 置 或 取消 模块 的 系统 服务 , 若 设置 成 功 , 显 示 为 "/”, 表 示 重 
启 计算 机 系统 时 自动 启动 该 服务 。 

(2) 模块 名 称 。 用 于 指明 当前 软件 模块 的 名 称 , 当 软件 已 经 启动 后 用 绿色 背景 显示 。 

(3) 模块 进程 ID 和 模块 端口 号 。 指 明 当 前 模块 的 进程 ID( 标 识 ) 和 端口 号 ,只 有 软 
件 服务 启动 后 才 会 显示 。 

(4) 动作 按钮 组 。 用 于 对 相关 软件 模块 实施 启动 .停止 .配置 和 日 志 等 操作 。 

(5) 系统 功能 按钮 组 。 用 于 调用 命令 行 窗口 .系统 服务 和 网 络 状 态 等 系统 操作 。 
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(6) 消息 列表 。 用 于 显示 当前 软件 服务 状态 和 系统 消息 的 列表 。 
3. 本 地 地 址 


通过 浏览 器 访问 网 站 时 ,网 站 中 的 每 个 页 面 都 有 一 个 网 络 地 址 , 即 网 址 。 网 址 包含 服 
务 器 地 址 和 服务 器 下 的 路 径 及 文件 名 ,如 “www. jlu. edu. cn/index. php”。 如 果 网 站 的 服 
务 器 软件 安装 在 本 地 计算 机 , 则 需要 将 服务 器 地 址 设置 为 本 地 地 址 。 

本 地 地 址 也 称 回路 地 址 ,用 Localhost 作为 访问 地 址 ,对 应 IPv4 地 址 127. 0. 0. 1 和 
IPv6 地 址 [ : :1], 网 页 服务 器 启动 后 ,可 以 通过 本 地 地 址 访问 服务 器 首页 。 


五 、 技 能 点 


(1) 下 载 和 安装 软件 。 能 充分 利用 互联 网 资源 获取 和 安装 MySQL 运行 环境 。 
(2) 设置 用 户 密码 。 为 XAMPP 管理 页 面 和 MySQL 数据 库 设 置 密码 ,并 用 新 密码 
登录 PHPMyAdmin 数据 库 管 理工 具 。 


六 、 注 意 事项 


(1) 初次 使 用 XAMPP 环境 时 ,XAMPP 管理 页 面 和 数据 库 管 理 员 账户 都 处 于 无 密 
码 状 态 。 为 了 防止 非法 用 户 通 过 网 络 算 改 服务 器 配置 ,确保 数据 库 安全 ,必须 尽快 添加 密 
码 保 护 ,并 使 用 新 密码 登录 PHPMyAdmin。 

(2) 在 启动 Apache 或 MySQL 服务 时 ,可 能 因 多 个 进程 使 用 相同 的 端口 号 ,造成 端 
口号 冲突 错误 , 单 击 系统 功能 按钮 组 的 Netstat 按钮 可 以 查看 系统 所 有 进程 的 端口 号 , 通 
过 关闭 冲突 进程 或 修改 软件 模块 默认 端口 号 可 以 排除 冲突 。 


七 、 实 验 步 又 


1. 下 载 和 安装 XAMPP 集成 软件 包 


(1) 通过 官方 网 站 下 载 。 打 开 浏 览 器 输入 www. xampp. org 进入 XAMPP 官方 网 
站 ,在 首页 上 选择 XAMPP for Windows 下 载 链接 ,下 载 最 新 版 本 的 XAMPP 集成 软件 
包 。 本 书 使 用 的 版 本 是 XAMPP 1. 8. 1 软件 包 。 

(2) 安装 XAMPP 集成 软件 包 。 双 击 下 载 的 XAMPP 安装 包 , 选 择 需 要 安装 的 组 件 ， 
设置 安装 路 径 ,如 D:\xampp, 等 待 安装 过 程 结束 即 可 。 


2. 配置 PHPMyAdmin 数据 库 管 理工 具 


(1) 打开 XAMPP 控制 面板 。 在 XAMPP 的 安装 目录 下 ,找到 xampp-control. exe 控 
制 面板 程序 ,双击 打开 控制 面板 ,如 图 1-1 所 示 。 
(2) 启动 Apache 和 MySQL 服务 。 在 控制 面板 中 分 别 单 击 Apache 和 MySQL 动作 
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按钮 组 中 的 Start 按钮 启动 相应 服务 , 若 成 功 启 动 , 则 Start 按钮 转换 成 Stop 按钮 ,在 消 
息 提 示 框 中 显示 服务 状态 为 running 。 

(3) 登录 XAMPP 欢迎 页 面 。 在 控制 面板 中 单 击 Apache 动作 按钮 组 中 的 Admin 按 
钮 ,进入 XAMPP"* 欢 迎 ” 页 面 。 初 次 访问 时 ,要 求 设置 语言 类 型 ,这 里 选择 “中 文 ”, 进 入 系 
统 设置 页 面 ,如 图 1-2 所 示 。 


国 XAMPP for Windows 


欢迎 使 用 XAMPP for Windows! 





English / Deutsch / Frand 





phpinfo() 
CD 入 


园 XAMppfir Windows 00 enn 


Perl 
perlinfo() 
Guest Book 





图 1-2 XAMPP 系统 设置 页 面 


(4) 添加 密码 保护 。 在 欢迎 页 中 选择 “安全 "链接 ,进入 XAMPP 安全 页 面 ,查看 当前 
安全 状态 。 在 安全 页 面 中 选择 http://localhost/security/xamppsecurity. php 链接 ,首先 
为 数据 库 的 root 用 户 输入 密码 后 单 击 “ 改 变 密码 ”按钮 ,然后 为 XAMPP 目录 输入 用 户 名 
和 密码 后 单 击 “ 保 护 XAMPP 文件 夹 "按钮 ,完成 安全 设置 。 

(5) 登录 PHPMyAdmin 主页 。 在 控制 面板 中 单 击 MySQL 动作 按钮 组 中 的 Admin 
按钮 ,在 打开 页 面 的 登录 框 中 输入 用 户 名 root 和 新 创建 的 密码 ,登录 PHPMyAdmin 主 
页 ,如 图 1-3 所 示 。 


当前 路 径 。 功能 选项 卡 










































phpMyAdmin NE | 
常 上 _ pandone 可 用 户 加 SL 图 导入 有 7 了 WS 
链接 技 钮 | 数据 库 服务 器 
(最 近 使 用 的 素 ) 
Ba 全 修改 宣 玛 . 二 127.0.0.1 via 
infomatio schena 和 汪汪 全 和 。 软件: JSQL 
gh2312_chinese_o 。 软件 版 本 : 5.5,27 -Jy99L 
国 ysal Commmity Server (GPL) 
加 ertommon sobma 。 协议 版 本 : 10 
一 。 用 户 : root@localhost 
hosein 1 条 TS unicaad 
_ | test (utf8) 
导航 面板 @ wbauth EE Lrenee @: L 
中 文 - Chinese simplified "| 
号 主题 : | pmahomme " 
， 字号: | 80% " apache/2.4.3 (Wirg2) 
DpenSSL/1.0.1c PHP/5.4.7 
六 更 多 设置 。 救 据 库 容 户 油 版 本 : libnysql 
图 1-3 PHPMyAdmin 主页 面 
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并 | 日 考题 


(1) 如 果 不 使 用 XAMPP 软件 包 , 要 成 功 运 行 PHPMyAdmin 需要 安装 哪些 软件 ? 
每 个 软件 的 作用 是 什么 ?如 何 获取 和 安装 ? 

(2) 如 果 不 使 用 XAMPP 控制 面板 ,可 以 通过 什么 方式 打开 PHPMyAdmin 主页 面 ? 

(3) 修改 root 用 户 密码 后 ,如 果 想 更 新 密码 应 该 如 何 操作 ? XAMPP 目录 的 用 户 名 
和 密码 有 什么 作用 ? 如 果 不 添加 会 有 什么 后 果 ? 


1.2 规划 用 户 及 其 权限 


一 、 实 验 目的 


通过 PHPMyAdmin 数据 库 管理 工具 ,为 人 才 招 聘 网 站 添加 数据 库 用 户 , 掌 握 如 何 创 
建 用 户 和 为 用 户 设置 不 同 的 权限 。 


二 、 实 验 任务 


(1) 使 用 PHPMyAdmin 为 MySQL 数据 库 分 别 添加 adminuser、webuser 和 visitor 
用 户 并 设置 密码 。 

(2) 使 用 PHPMyAdmin 为 新 建 用 户 设 定 管理 员 、 业 务 用 户 和 访问 用 户 权 限 。 

(3) 通过 用 户 表 查看 用 户 信息 。 


三 、 任 务 分 析 


一 个 网 络 数据 库 应 用 系统 应 该 有 多 种 类 别 的 用 户 ,为 防止 用 户 非法 访问 数据 库 ,应 该 
根据 任务 需求 按照 最 小 权限 原则 ,为 不 同类 型 用 户 授予 不 同 的 权限 。 对 于 人 才 招 聘 网 站 
的 访问 用 户 ,根据 数据 库 操作 权限 可 以 分 为 系统 管理 员 、 业 务 人 员 和 应 聘 人 员 3 个 类 别 ， 
每 个 类 别 都 可 以 包含 多 个 用 户 。 

系统 管理 员 类 用 户 需 要 执行 服务 器 设置 .创建 用 户 和 权限 管理 等 操作 ,拥有 最 高 级 的 
权限 :业务 人 员 类 用 户 需要 数据 表 级 别 的 所 有 操作 以 及 执行 存储 过 程 和 创建 临时 表 的 权 
限 ;而 应 聘 人 员 类 用 户 只 拥有 单一 的 查询 权限 。 


四 、 预 备 知识 





(1) 最 小 权限 原则 。 是 指 用 户 完成 用 户 任务 所 需 的 最 低级 别 的 权限 。 最 小 权限 原则 
是 系统 安全 中 最 基本 的 原则 之 一 。 
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(2) MySQL 的 权限 管理 。MySQL 的 一 个 重要 特性 就 是 支持 复杂 的 权限 管理 ,将 用 
户 权限 分 为 管理 级 权限 、 数 据 库 级 权限 和 数据 表 级 权限 ,通过 在 不 同 级 别 中 选择 对 应 的 数 
据 库 操作 ,实现 多 样 化 权限 配置 。 此 外 ,MySQL 使 用 用 户 名 加 主机 名 作为 标识 来 区 分 用 
户 , 用 户 在 不 同 主机 登录 拥有 不 同 的 权限 。 


五 、 技 能 点 


(1) 用 户 分 类 。 为 人 才 招 聘 数据 库 网 站 设计 不 同类 型 的 用 户 并 授予 不 同 的 操作 
权限 。 

(2) 创建 数据 库 用 户 。 用 PHPMyAdmin 创建 数据 库 用 户 ,设置 登录 主机 和 密码 。 

(3) 分 配 用 户 权 限 。 使 用 “ 按 数 据 库 指定 权 限 ”" 和 * 按 表 指 定 权 限 ” 为 用 户 分 配 不 同类 
别 的 权限 。 


六 、 注 意 事 项 


(1) root 用 户 属于 超级 管理 员 账 户 , 默 认 只 能 本 地 访问 ,不 能 通过 网 络 远程 访问 ,所 
以 通常 需要 创建 可 在 任意 主机 登录 的 管理 员 用 户 。 

(2) 从 安全 角度 讲 , 创 建 用 户 时 一 定 要 为 用 户 设 定 密码 ,为 防止 其 他 用 户 通过 访问 用 
户 表 查看 密码 ,通常 还 需要 使 用 加 密 算法 生成 密 文 进行 存储 。 


七 、 实 验 步骤 


(1) 创建 用 户 。 在 PHPMyAdmin 主页 中 选择 “用户 ”选项 卡 一 "添加 用 户 ? 选 项 ,在 
弹出 的 对 话 框 中 设置 用 户 登 录 信 息 : 用 户 名 为 adminuser, 主 机 选择 为 任意 主机 ”, 设 置 
登录 密码 , 单 击 “ 添 加 用 户 ” 按 钮 完成 用 户 的 创建 。 用 同样 的 方法 依次 创建 webuser 和 
visitor 两 个 用 户 。 

(2) 设 定 用 户 权 限 。 打 开 * 用 户 概况 "页面 , 单 击 adminuser 用 户 后 的 “编辑 权限 ” 链 
接 , 如 图 1-4 所 示 ,打开 ”编辑 权 限 ? 对 话 框 。 在 此 对 话 框 中 可 以 按 数据 库 或 数据 表 设 置 用 
户 的 所 有 操作 权限 以 及 修改 和 复制 用 户 信息 等 操作 。 














用 户 主机 室友 全 局 权限 岛 授权 操作 

国人 一 se 否 局 编 生 权限 园 导 出 

口 人 总 limx 否 SA 天 ”局 编辑 权限 局 导出 | 

国 任意 localhost 否 。 SAGE 否 。 龟 编辑 权限 必 号 出 

ainser % 是 vshcE 到 一 单 击 “ 编 辑 权 限 ” 
国 nail localhost 是 USAGE 否 。 属 编辑 权限 转 导出 链接 
口 pma localhost 否 VSAGE 否 ”已 编辑 权限 好 号 出 | 

国 roet lirmxz 否 ALL PRIVILEGES 是 局 编辑 权限 园 号 出 | 

口 root localhost 是 ”ALL PRIYILEGES 是 ”已 编辑 权限 忆 导出 | 

国 testuser 入 是 VSASE 否 ” 厂 编辑 权限 转 导出 | 

1-4 用 户 概况 
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adminuser 为 超级 用 户 ,拥有 数据 库 服务 器 的 所 有 权限 。 单 击 * 全 局 权限 * 中 的 “全 
选 ”>“ 执 行 ” 按 钮 完成 权限 设置 ,此 时 “用 户 概况 "页面 的 “授权 ” 列 ,adminuser 的 值 变 为 
“是 ”。 

webuser 和 visitor 用 户 拥有 某 个 数据 库 的 权限 ,此 处 以 MySQL 数据 库 为 例 ， 
webuser 拥有 该 数据 库 的 数据 管理 权限 。 打 开 webuser 的 “编辑 权限 "对话 框 ,在 “ 按 数 据 
库 指定 权限 ”列表 框 中 选择 数据 库 为 MySQL, 单 击 “ 执 行 "按钮 ,选中 “数据 " 列 的 所 有 权 
限 ,如 图 1-5 所 示 。 


编辑 权限 : 用 户 Webuser'@%"- 数据 库 mysgq/ 
按 数 据 库 指定 权限 (全 选 / 全 不 选 ) 


主 合 : MySQL 纳 忱 富 际 全 以 二 广 避 示 


# DELETE DEOF 
CREATE TEIPORARY TABLES 
SHOW VIEW 
CREATE ROUTINE 
ALTER FOUTINE 
EXECUTE 
CREATE VIEW 
EVENT 
TRIGOER 








图 1-5 用 户 权限 设 定 


visitor 只 拥有 数据 库 的 查看 权限 。 在 visitor 用 户 的 “编辑 权限 ”对 话 框 中 ,选择 “ 按 
数据 库 指定 权限 ”的 值 为 MySQL, 单 击 “ 执 行 ” 按 钮 ,选中 “数据 ” 列 的 SELECT 权限 。 

(3) 查看 用 户 信息 。 在 PHPMyAdmin 主页 的 导航 面板 中 ,选择 mysql 数据 库 一 user 数 
据 表 ,打开 user 表 。 在 user 表 中 可 以 查看 到 用 户 adminuser、webuser 或 visitor 所 设 定 的 主 
机 、 密 码 和 操作 权限 。 分 别 使 用 三 个 用 户 重新 登录 PHPMyAdmin 查看 可 操作 的 内 容 。 


八 、 思 考题 


(1) 如 何 删除 不 符合 要 求 的 用 户 ? 如 何 修改 一 个 用 户 的 密码 ? 
(2) 如 果 为 数据 库 添 加 多 个 具有 相同 类 别 的 用 户 , 可 以 如 何 简化 操作 ? 


1.3 设计 人 才 招聘 数据 库 及 其 表 


一 、 实 验 目 的 


设计 并 建立 人 才 招聘 网 站 数据 库 和 数据 表 , 理 解 网 站 数据 库 的 设计 过 程 ,掌握 使 用 
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PHPMyAdmin 创建 MySQL 数据 库 及 数据 表 的 方法 。 
二 、 实 验 任务 


(1) 使 用 PHPMyadmin 创建 名 为 RCZP 的 人 才 招聘 数据 库 。 
(2) 按照 表 1-1 一 表 1-4 的 设计 要 求 , 在 RCZP 数据 库 中 创建 相应 的 数据 表 。 


三 、 任务 分 析 


建立 数据 库 应 用 系统 的 首要 工作 是 设计 并 创建 数据 库 及 数据 表 。 对 于 人 才 招 聘 网 
站 ,根据 网 站 功能 将 数据 库 分 为 岗位 表 GWB、 岗 位 成 绩 表 GWCJB、 应 聘 人 员 表 YPRYB 
和 公司 表 GSB, 根 据 表 1-1 一 表 1-4 中 设计 的 数据 表 结 构 ,完成 RCZP 数据 库 和 相关 数据 
表 的 创建 。 





四 、 预 备 知识 


(1) 数据 库 编 码 类 型 。 使 用 PHPMyadmin 添加 数据 库 、 数 据 表 和 字段 时 ,可 以 指定 
所 含 内 容 的 编码 类 型 ,也 称 为 整理 规则 。 对 于 中 文 数据 ,可 以 采用 不 区 分 大 小 写 的 中 文 编 
码 类 型 gb2312_chinese_ci 或 通用 编码 类 型 utf8_general_ci。 

(2) 主键 。 用 于 唯一 标识 表 中 记录 的 最 少 字 段 集 , 用 于 唯一 确定 一 个 实体 。 主 键 可 
以 由 一 个 字段 或 由 多 个 字段 组 成 ,分 别称 为 单字 段 主键 或 多 字段 主键 。 主 键 中 包含 的 字 
段 是 主 属性 ,在 PHPMyAdmin 页 面 中 , 主 属性 加 下 面 线 标识 。 


五 、 技 能 点 


(1) 设计 数据 表 。 根 据 数据 库 应 用 系统 的 要 求 设计 所 需 的 数据 表 结 构 。 
(2) 建立 数据 表 。 使 用 PHPMyAdmin 建立 数据 库 , 并 能 按照 数据 表 结 构 正 确 填写 
数据 表 中 的 字段 信息 ,实现 数据 库 中 数据 表 的 创建 。 


六 、 注 意 事项 


(1) 对 于 中 文 数据 ,如 果 采 用 默认 的 整理 规则 ,在 数据 显示 时 可 能 出 现 乱 码 或 乱 序 的 
问题 。 因 此 在 建立 数据 库 和 数据 表 时 需要 将 中 文 内 容 设 定 为 支持 中 文 的 编码 类 型 。 

(2) 在 设计 字段 的 长 度 、SET 类 型 值 和 上 默认 值 时 ,英文 字母 .数字 和 标点 符号 应 一 律 
以 英文 半角 方式 输入 ,否则 可 能 产生 语法 错误 。 

(3) 在 PHPMyAdmin 页 面 中 ,打开 无 记录 的 数据 表 时 “浏览 "选项 卡 不 可 用 ,只 能 
查看 数据 表 结构 ,通过 “插入 ”选项 卡 添加 数据 记录 后 才能 使 用 。 使 用 “操作 ”选项 卡 可 以 
实现 修改 数据 表 名 ,修改 整理 规则 数据 表 移 动 和 复制 等 操作 。 
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七 、 实 验 步骤 


1. 创建 人 才 招聘 网 站 数据 库 


在 PHPMyAdmin 主页 中 选择 “数据 库 ” 选 项 卡 ,打开 “数据 库 ” 页 面 。 在 “新 建 数 据 
库 ” 的 文本 框 中 输入 RCZP ,在 “整理 ”列表 中 选择 gb2312_chinese_ci, 单 击 “ 创 建 ” 按 钮 完 
成 人 才 招聘 数据 库 的 创建 。 成 功 创建 的 数据 库 会 显示 到 PHPMyAdmin 主页 面 的 导航 面 
板 , 通 过 单 击 数据 库 名 可 以 直接 跳 转 到 该 数据 库 页 面 。 


2. 创建 数据 表 


(1) 创建 岗位 表 。 岗 位 表 是 人 才 招聘 网 站 中 用 于 保存 招聘 岗位 信息 的 数据 表 。 在 导 
航 面板 中 单 击 RCZP 数据 库 , 进 入 数据 库 页 面 。 在 “新 建 数 据 表 ” 框 架 中 ,输入 “名 字 ” 为 
GWB、“ 字 段 数 ” 为 11, 单 击 “ 执 行 " 按 钮 。 在 GWB 表 页 面 中 (如 图 1-6 所 示 ) ,按照 表 1-1 
填写 各 个 字段 的 名 称 数据 类 型 和 长 度 等 信息 。 单 击 “ 保 存 ” 按 钮 完成 岗位 表 的 创建 。 
















































































[3 关 型 全 长 度 [但 号 默认 全 
次 位 编号 CHAR 国 后 ] 苇 加 
商 位 名 称 YaRCHAR 可 ia 无 加 
| 最低 学 历 ENUM 国 上 .2.3.4.5 | | 定义 | 
ENUM 或 SET 3 
数 希 过 长 ? 读 
了 
他 
最 低 学 位 [ENu 加 由 .2.3.45' ex 
ENM 职 SET 加 ] 
束 有 过 性? 区 
同 
A ] [mavwr 国 B [EX _ 国 
1 
年龄 上 了 碌 [TNvNT -9 定义 加 
®@ | 
医 本 [MEDIUMINT 司 话 X， 
证 斌 赂 天 此 网 | [TINYINT 器 6B 定义 : 习 
p 
[ 尖 这 区 [oATE ~ NULL ~ 
| 聘任 要 来 TINYTEXT ~ NULL al 
| 公司 名 称 [VARCHAR 国 lm NULL 加 
图 1-6 GWB 表 结构 页 面 
表 1-1 GWB 表 的 结构 
字段 名 称 数据 类 型 长 度 / 值 设计 说 明 
岗位 编号 Char 条 非 空 值 ,GWB 表 的 主键 和 主 属性 
岗位 名 称 Varchar 30 非 空 值 
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续 表 
字段 名 称 数据 类 型 长 度 / 值 设计 说 明 
“默认 值 ” 设 为 3。 将 “注释 " 列 设 为 “1 无 要 求 ;2 专 
科 ;3 本 科 ;4 硕士 ;5 博士 ” 
“默认 值 " 设 为 2。 将“ 注释" 列 设 为 “1 无 要 求 ;2 学 





最 低 学 历 Enum 2 














最 低 学 位 Enum 1',2','3',4','5' 上 ;3 双 学 十 ;4 硕士 ;5 博士 ” 
人 数 Tinyint 3 “上 默认 值 " 设 为 1。 无 符号 整数 
年 龄 上 限 Tinyint |2 “默认 值 " 设 为 60。 无 符号 整数 
年 薪 Mediumint | 8 





笔试 成 绩 占 总 成 绩 的 百分比 , 非 负 值 .“ 默 认 值 ” 设 


了 i 
笔试 成 绩 比 例 | Tinyint 3 为 0; 表示 无 笔试 











笔试 日 期 Date 
聘任 要 求 Tinytext 
公司 名 称 Varchar 50 非 空 值 ,设置 为 索引 











每 个 表 都 应 该 有 主键 。 如 需要 为 表 设 置 主键 ,首先 在 表 页 面 中 选择 “结构 ?选项 卡 ,在 
表 结 构 列表 中 ,可 以 通过 单 击 字段 名 右 侧 的 “主键 "链接 设置 字段 为 主键 。 
(2) 创建 公司 表 。 公 司 表 是 人 才 招 聘 网 站 中 用 于 保存 招聘 公司 信息 的 数据 表 。 按 照 
表 1-2 所 示 的 设计 要 求 , 参 照 步骤 (1) 中 的 操作 过 程 建立 GSB 表 。 
表 1-2 GSB 表 的 结构 


























字段 名 称 数据 类 型 长 度 / 值 设计 说 明 
公司 名 称 Varchar 50 非 空 值 ,GSB 表 的 主键 和 主 属性 
地 址 Varchar 50 非 空 值 

注册 日 其 Date 

注册 人 数 Smallint 5 

简介 Text 

邮政 编码 Char 6 

注销 Tinyint 1 “默认 值 ” 设 为 0。 表 示 尚未 注销 
宣传 片 Longblob 











(3) 创建 应 聘 人 员 表 。 应 聘 人 员 表 是 人 才 招 聘 网 站 中 用 于 保存 应 聘 人 员 信 息 的 数据 
表 。 按 照 表 1-3 所 示 的 设计 要 求 , 参 照 步骤 (1) 中 的 操作 过 程 建立 YPRYB 表 。 
表 1-3 YPRYB 表 的 结构 
字段 名 称 数据 类 型 长 度 / 值 设计 说 明 
身份 证 号 Char 18 非 空 值 .YPRYB 表 的 主键 和 主 属性 
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续 表 









































字段 名 称 数据 类 型 长 度 / 值 设计 说 明 

姓名 Varchar 10 

婚 否 Tinyint 1 “默认 值 " 设 为 0。 表示 未 婚 

最 后 学 所。| ow。 | st, | 要 以 全 认为 1 特 - 放 各" 列 设 为 1 无 12 专科 
Er ee 二 大 生生 考生 和 和 区 和 了 拓 人 系 二 
所 学 专业 Varchar 30 

通信 地 址 Varchar 50 

邮政 编码 Char 6 

E-mail 账号 Varchar 30 

QQ 账号 Varchar 30 

固定 电话 Varchar 20 

移动 电话 Varchar 15 

密码 Varchar 10 

个 人 简历 Text 











(4) 创建 岗位 成 绩 表 。 本 书 中 的 人 才 招 聘 网 站 可 以 为 招聘 公司 提供 应 聘 人 员 考 核 成 
绩 的 保存 功能 ,其 数据 保存 到 岗位 成 绩 表 中 。 按 照 表 1-4 所 示 的 设计 要 求 ,参照 步骤 (1) 
中 的 操作 过 程 建立 GWCJB 表 。 


表 1-4 GWCJB 表 的 结构 





























字段 名 称 数据 类 型 长 度 / 值 设计 说 明 

身份 证 号 Char 18 非 空 值 ,GWCJB 表 的 主键 和 主 属性 之 一 
岗位 编号 Char 5 非 空 值 ,GWCJB 表 的 主键 和 主 属性 之 一 
资格 审核 Tinyint 于 “默认 值 " 设 为 0。 表 示 尚 未 通过 

笔试 成 绩 Tinyint 3 “默认 值 " 设 为 0。 表 示 尚 未 参加 考试 或 0 分 
面试 成 绩 Tinyint 3 “默认 值 " 设 为 0。 表 示 尚 未 参加 考试 或 0 分 


八 、 思 考题 


(1) 如 果 要 创建 一 个 在 线 购书 网 站 ,其 数据 库 和 表 应 该 怎么 设计 ? 
(2) 如 何 修改 一 个 已 存在 的 数据 库 名 称 ? 如 何 修改 数据 表 的 名 称 ? 
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1.4 设计 人 才 招 聘 数据 表 间 关联 
一 、 实 验 目 的 
学 习 使 用 PHPMyAdmin 数据 库 管理 工具 在 数据 库 的 不 同 表 之 间 建 立 关联 的 方法 。 
理解 表 关联 和 参照 完整 性 的 含义 。 
二 、 实 验 任务 
添加 关联 和 参照 完整 性 ,完善 人 才 招聘 数据 库 的 设计 。 
三 、 任 务 分 析 


为 了 保证 数据 库 的 一 致 性 和 完整 性 ,数据 库 表 之 间 通 常 要 建立 关联 ,并 设 定 关联 的 约 
束 规则 , 即 参 照 完整 性 。 实 施 了 参照 完整 性 ,对 主 表 进 行 删除 和 更 新 操作 时 ,关联 的 从 表 
要 做 相应 的 改变 ,防止 数据 表 由 用 户 错误 操作 导致 引用 了 不 存在 的 数据 。 

MySQL 数据 库 系 统 可 以 通过 SQL 语句 创建 关联 和 参照 完整 性 ,也 可 以 通过 
PHPMyAdmin 中 的 “关联 设计 器 ”( 如 图 1-7 所 示 ) 实 现 可 视 化 的 快速 创建 。 













BB | so :9 eb 人 sp Pryb 
国 | 9 山 位 编号 : char(5) 身份 证 号 : char(18) 
“创建 关系 ” a 
工具 一 小 | | 昌 沿 人 创建 关系 表 间 关联 线 te 3 varchar (10) 
站 © 9 最 个 Fa KEY # 既 否 ， tirgirt (1) 
最 人 2 4 最 后 学 历 :set fl 2 3 5 ) 
9 # 人 基 ER CASCADE ， Wi 9 最 后 学 位 : set (1,'2 ,3 ,4',"5) 
加 | | 全 所 学 专业 ;varchar(30) 
| 友 | + 年 到 日 通信 地 址 : varchar(50) 
设计 器 _ |@ | | * 委 这 -一 0 邮政 编码 : char(6) 
工具 栏 一 | | as 全 本 eh 人 mEmail 账 号 ;varchar (30) 
2 © mf 身份 证 号 : char (18) a) 
图 | 0 公司 名 称 :varchar(40) 册 位 编号 char (5) 固定 电话 :varchar (20) 
全 # 资 格 审 校 : tinyint (1) 9 移动 电话 :varchar (15) 
一 4 等 斌 所 绩 :tinyint (3) unsignedl 密码: varchar(l0) 
上 面试 成绩 ; tinyint (3) unsignedl 。 日 个 人 简历 : text 








图 1-7 关联 设计 器 


四 、 预 备 知识 


(1) 表 间 关联 。 在 一 个 数据 库 中 ,不 同 数据 表 之 间 经 常 存在 直接 或 间接 的 联系 , 表 间 
关联 就 是 通过 两 个 表 中 具有 相同 含义 的 字段 建立 起 来 的 。 例 如 ,岗位 成 绩 表 的 身份 证 号 
和 应 聘 人 员 表 的 身份 证 号 之 间 ; 岗 位 成 绩 表 的 岗位 编号 和 岗位 表 的 岗位 编号 之 间 等 。 通 
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常 主键 所 在 的 表 为 主 表 , 外 键 所 在 的 表 为 从 表 。 
(2) 参照 完整 性 。 是 表 间 关联 的 一 种 约束 规则 。 当 两 个 表 建 立 关 联 后 ,更 新 删除 或 
插入 表 中 的 数据 记录 时 ,通过 参照 引用 相关 联 的 另 一 个 表 中 的 数据 ,检查 操作 是 否 正确 。 


五 、 技 能 点 


(1) 设计 数据 表 关联 。 能 够 根据 数据 库 中 所 有 表 的 结构 , 找 出 需要 添加 关联 的 数据 
表 及 对 应 的 字段 。 

(2) 使 用 关联 设计 器 。 掌 握 PHPMyAdmin 关联 设计 器 的 功能 和 常用 工具 的 使 用 
方法 。 

(3) 添加 表 关 联 和 设 定 参照 完整 性 。 能 够 使 用 关联 设计 器 建立 数据 表 的 关联 ,根据 
需求 设 定 参 照 完整 性 。 


六 、 注 意 事 项 


(1) 要 在 两 个 表 之 间 添 加 关联 ,需要 满足 以 下 要 求 : 两 表 中 具有 相同 含义 的 字段 都 
定义 了 索引 ,数据 类 型 和 长 度 要 匹配 ,从 表 的 外 键 值 都 在 主 表 中 。 如 果 不 满足 这 些 要 求 ， 
则 无 法 添加 关联 。 

(2) 要 解除 两 个 数据 表 的 关联 ,可 以 通过 双击 “关联 线 ”, 打 开 是 否 删除 的 提示 框 , 单 
击 “确定 ”按钮 后 实现 删除 。 


七 、 实 验 步骤 


(1) 在 PHPMyAdmin 主页 中 ,选择 “数据库 ” 一 rczp 数据 库 一 "设计 器 ”选项 卡 ,打开 
人 才 招 聘 数 据 库 的 “设计 器 ?页 面 。 人 才 招 聘 数据 库 中 的 所 有 数据 表 及 其 表 结 构 会 自动 显 
示 到 该 页 面 ,通过 鼠标 拖 忠 表 名 所 在 的 标题 栏 可 以 移动 表 的 位 置 。 

(2) 在 “设计 器 ”页面 中 ,如 图 1-7 所 示 , 从 左 侧 的 “工具 栏 ”里 选择 “创建 关系 ”工具 ， 
在 想 要 添加 关联 的 数据 表 之 间 , 先 后 单 击 主键 和 外 键 ,此 时 会 弹出 “创建 关系 ”对 话 框 ,用 
于 设 定 参 照 完整 性 在 删除 和 更 新 时 的 控制 方式 。 这 里 可 以 选择 CASCADE 级 联 方式 , 单 
击 * 确 定 ” 按 钮 结束 参照 完整 性 设 定 ,关联 的 表 之 间 会 显示 一 条 关联 线 。 

(3) 用 步骤 (2) 中 的 方式 ,以 YPRYB 表 为 主 表 ,GWCJB 表 为 从 表 通 过 “身份 证 号 ” 字 
段 建立 关联 ;以 GWB 表 为 主 表 ,GWCJB 表 为 从 表 , 通 过 * 岗 位 编号 ”字段 建立 关联 ;以 
GSB 表 为 主 表 ,GWB 表 为 从 表 , 通 过 “公司 名 称 ” 字 段 建立 关联 。 


八 、 思 考题 


(1) 怎么 验证 参照 完整 性 对 保持 数据 一 致 起 到 的 作用 ? 
(2) 除了 关联 设计 器 ,还 可 以 通过 什么 方式 添加 数据 表 的 参照 完整 性 ? 
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1.5 维护 人 才 招聘 数据 库 


一 、 实 验 目 的 


通过 数据 的 输入 、 修 改 和 删除 等 操作 ,验证 数据 表 设 计 的 合理 性 和 参照 完整 性 的 作 
用 。 通 过 数据 的 导入 和 导出 ,掌握 数据 备份 及 不 同 软件 间 数 据 交换 的 过 程 和 方法 。 


二 、 实 验 任务 


(1) 登录 PHPMyAdmin 数据 库 管 理工 具 , 向 人 才 招聘 数据 库 各 表 添 加 如 图 1-8 一 


图 1-11 所 示 的 数据 。 
(2) 在 已 有 数据 的 基础 上 ,对 其 进行 维护 性 的 修改 和 删除 操作 。 


(3) 使 用 PHPMyAdmin 工具 ,对 数据 库 中 的 数据 实现 多 种 格式 的 导 和 人 和 导出 操作 。 














医大 一 院 长 春 市 朝阳 区 130012 





1948-01-01 


名 称 地 址 .注册 日 期 ”注册 人 数 “简介 邮政 编 玛 。 注销 ”宣传 片 
工商 前 进 支行 长 春 市 高 新 区 。 1991-10-0l 2 于 2010 年 新 迁 入 高 新 区 。 130012 0 md 
食 府 快餐 店 ”长 春 经 济 开发 区 2013-01-03 100 待 整理 2015-1 0 | 
食 府 快 净 店 a 长 春 经 济 开发 区 2015-10-14 10 待 整理 130103 0 Md 
甘 讯 总 公司 。 北京 市 中 关 村 。 2001-07-01 。 ”2000 待 整理 100201 0 | 



























EE RE 和 本 本 后 划 折 ”所 学 和 下 一 遂 人 开征 语 抽 一 -nni1 包 人 
ee 交 ， 生 而 和 六 me EE EE 
11980L19921001132X oa 4 全 融 学 北京 两 城区 10012%0 wineina com 1g08530753 010- 15g8F900157 5678 
德 外 大 街 4 号 56561603 
|2t990L 190001011361 0 5 5 法 学 Re 1300654 haoahuaifeina. con 1608622733 13788590016 holes 
229901 199305011524 0 3 4 会 计 学 卡 大 前 进 大 130012 LILIecina con 2508522133 13888599912 181818| 
衔 2099 号 
nooo03050115 R00 小 soningacota oon 2606622199 e97890016 j6ac0 
千 与 拉 术 。 自 史 号 
ED | 0 3 2 会计 学 长 春 前 进 大 130012 1d@jlu. ed. cn 2d08522133 M31- 13986099912 )234 
科 2599 号 人 61560032 
图 1-9 应 聘 人 员 表 数据 
| 卫 本 S。 丙 友和 称 ”最 环 学 历 大 环节 位 人数” 盾 茜 E 限 ” 盾 攻 于 到 昌 二 ”可 在 要 来 | 








no 


2017-01-14 有 驾照， 笔试 经 济 学 + 全 融 工商 前 进 支行 | 





3 2 a 
lA0002 ”银行 柜员 2 1 5 多。 10 人 0 ”201701-15 计算 机 二 驾 ， 笔试 : 全 融 + 会 计 学 工商 前 进 支行 | 
[AD003 律师 3 3 3 0 3 印 ”2017-01-15 有 和 驾照， 笔试 经 济 法 {金融 工商 前 进 支行 | 
Lanom 会 计 可 3 3 下 0 多 ”2017-05-10 笔试 经 济 学 :全 融 工商 前 进去 行 | 
B0001 经理 助理 5 5 3 0 12 下 ”201T-01-21 笔试 : 经 济 学 + 人 力 资源 肪 讯 总 公司 
ooo2 理财 师 。 3 加 到 和 9 加 ”2017-01-22 笔试 : 径 济 法 H 务 管理 靶 讯 总 公司 
60003 岗 前 培训 师 3 和 3 入 10 50 ”2017-05-08 笔试 经 济 学 + 金融 工商 前 进 支行 | 





图 1-10 岗位 表 数 据 
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身份 证 号 商 多 编号 资格 审核 ”笔试 威 绩 。 面试 成 续 


11980119921001132% A0001 1 T5 9 
11980119921001132x B0001 可 5 30 
1198011992100113ZX B0002 1 90 85 
219901199001011351 40002 0 no mn 
219901199001011351 B0001 0 75 60 
219901199001011351 B0002 89 38 
229901199305011575 A0001 0 90 75 





图 1-11 岗位 成 绩 表 数 据 


三 、 任务 分 析 


数据 库 维护 主要 指数 据 库 创建 后 对 数据 表 中 数据 的 管理 工作 。 在 PHPMyAdmin 的 
数据 表 页 面 中 ,通过 “插入 ”选项 卡 实现 表 中 数据 的 添加 ,通过 “浏览 ”选项 卡 实现 表 中 数据 
的 查看 ,修改 和 删除 。 

从 数据 安全 的 角度 ,为 防止 出 现 操 作 失 误 或 系统 故障 导致 数据 丢失 ,数据 库 还 需要 提 
供 备份 和 恢复 的 功能 ,PHPMyAdmin 中 通过 “导入 ”和 "导出 ”选项 卡 实现 。 此 外 ,数据 的 
导入 和 导出 也 可 以 实现 MySQL 数据 库 与 其 他 软件 间 的 数据 交换 。 


四 、 预 备 知识 


(1) 结构 化 查询 语言 ,简称 SQL, 是 数据 库 中 通用 的 数据 管理 语言 ,也 是 数据 库 脚本 
文件 的 扩展 名 。 在 PHPMyAdmin 中 ,对 数据 库 的 管理 工作 ,都 可 以 用 SQL 语句 来 实现 ， 
通过 “预览 SQL 语句 ”按钮 ,可 以 查看 当前 操作 对 应 的 SQL 语句 。 

(2) 关联 数据 的 管理 。 当 管理 数据 表 中 数据 时 ,如 果 当 前 表 和 其 他 表 存 在 关联 和 参 
照 完 整 性 ,输入 从 表 数 据 时 可 以 手动 选择 已 存在 的 主 表 数据 。 浏 览 从 表 数 据 时 ,也 可 以 通 
过 单 击 外 键 值 直接 跳 转 到 主 表 对 应 记录 中 。 


五 、 技 能 点 


(1) 数据 输入 。 能 够 掌握 PHPMyAdmin 中 表 数 据 的 输入 方法 。 

(2) 数据 修改 和 删除 。 能 够 通过 “浏览 ”选项 卡 完成 数据 的 查看 、 修 改 和 删除 工作 。 

(3) 数据 导入 和 导出 。 能 够 将 数据 库 和 数据 表 内 容 导 出 成 脚本 文件 或 其 他 类 型 文 
件 ,能 将 其 他 数据 库 文件 或 数据 文档 导入 当前 数据 库 。 
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六 、 注 意 事项 


(1) 若 两 个 数据 表 之 间 设 置 了 参照 完整 性 如 级 联 更 新 和 级 联 删除 之 后 ,在 对 表 中 数 
据 进行 修改 和 删除 时 ,可 能 会 造成 关联 表 中 数据 的 冲突 而 导致 操作 异常 。 请 确保 以 下 几 
点 : 不 得 在 从 表 中 添加 主 表 中 没有 关联 的 记录 ;不 能 修改 导致 从 表 出 现 孤 立 记录 的 主 表 
的 值 ;不 能 删除 主 表 在 从 表 中 有 匹配 的 记录 。 

(2) 向 数据 表 中 导入 数据 时 要 注意 数据 的 结构 。 通 过 导入 创建 的 数据 表 有 可 能 不 完 
善 , 如 缺少 主键 ,缺少 表 间 关联 和 未 设置 参照 完整 性 等 ,需要 对 其 进行 调整 。 

(3) 导出 数据 时 ,PHPMyAdmin 提供 不 同 的 文件 格式 ,生成 相应 的 文件 。 如 果 默 认 
格式 不 满足 要 求 ,可 以 通过 “ 自 定义 ”选项 进行 修改 ,并 可 以 保存 为 模板 (template) 以 便于 
下 次 使 用 。 


七 、 实 验 步骤 


1. 插入 数据 


(1) 在 PHPMyAdmin 主页 面 的 导航 面板 中 ,选择 RCZP 数据 库 一 YPRYB 数据 表 一 
“插入 ”选项 卡 , 打 开 数 据 表 的 插入 页 面 。 按 照 图 1-9 所 示 的 内 容 , 分 别 在 相应 字段 名 右 侧 
的 * 值 ” 域 中 为 应 聘 人 员 表 添加 数据 。 

(2) 填写 一 条 记录 之 后 ,可 以 单 击 该 条 记录 后 的 “执行 "按钮 ,保存 该 记录 ,也 可 以 依 
次 填写 完 所 有 记录 后 再 单 击 最 后 的 “执行 ”按钮 统一 添加 。 如 果 当 前 页 可 添加 记录 条 数 不 
够 ,可 以 输入 “继续 插入 "的 行 数 ,增加 可 添加 记录 条 数 。 

(3) 用 同样 的 方式 按照 图 1-8、 图 1-10 和 图 1-11 为 GWB、GSB 和 GWCJB 添加 数据 。 


2. 修改 和 删除 数据 


(1) 在 导航 面板 中 ,选择 RCZP 数据 库 ~GWCJB 数据 表 , 打 开 岗 位 成 绩 表 浏览 页 面 ， 
选中 所 有 “笔试 成 绩 ” 大 于 80, 资 格 审 查 为 0 的 记录 , 单 击 “ 编 辑 " 按 钮 。 在 跳 转 页 面 中 将 
记录 的 “资格 审查 ” 值 修 改 为 1 并 单 击 “ 执 行 "按钮 。 

(2) 在 岗位 成 绩 表 浏 览 页 面 ,选中 所 有 “面试 成 绩 ” 小 于 70 的 记录 , 单 击 “ 删 除 ” 按 钮 。 


3. 导入 和 导出 数据 


(1) 在 导航 面板 中 ,选择 RCZP 数据 库 一 GSB 数据 表 一 “导出 ”选项 卡 ,选择 格式 为 
SQL, 单 击 * 执 行 ?按钮 。 导 出 的 数据 表 文 件 gsb. sql 保存 在 当前 浏览 器 的 下 载 文件 夹 内 ， 
可 以 使 用 记事 本 等 程序 打开 该 文件 查看 内 容 。 

(2) 在 导航 面板 中 : 单 击 RCZP 数据 库 , 选 择 GSB 表 右 侧 的 “清空 "按钮 ,清空 该 数据 
表 。 选 择 “ 导 入 "选项 卡 , 单 击 “ 选 择 文件 ”按钮 ,找到 并 选中 gsb. sql 文件 , 单 击 “ 执 行 ” 按 
钮 完成 数据 的 导入 。 
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并 思考 题 


(1) 关联 数据 管理 有 什么 特点 ? 要 实现 关联 数据 管理 ,应 该 如 何 设计 数据 表 ? 

(2) 能 否 将 数据 表 输 出 成 Excel 文件 ? 如 果 想 要 在 Excel 软件 内 修改 数据 ,在 导入 到 
数据 库 后 应 该 怎么 操作 ? 

(3) 在 执行 数据 编辑 和 删除 操作 时 会 出 现 哪些 错误 ? 表现 为 什么 ? 
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MySQL 是 目前 比较 流行 的 关系 型 数据 库 管理 系统 之 一 ,在 Web 应 用 开发 方面 ， 
MySQL 也 是 比较 适用 的 关系 数据 库 管 理 系 统 。 它 支持 访问 数据 库 的 结构 化 查询 语言 
SQL。MySQL 具有 体积 小 .速度 快 和 源码 开放 等 特点 ,是 适 于 管理 中 小 型 网 站 的 数据 
库 , 结 合 PHP 和 Apache 可 组 成 良好 的 软件 开发 环境 。 





2.1 MySQL 客户 端的 登录 及 应 用 


一 、 实 验 目 的 

掌握 MySQL 客户 端 登 录 及 退出 方法 ,利用 MySQL 进行 基本 的 数据 库 管 理 。 
二 、 实 验 任务 

(1) 用 MySQL 命令 行 方 式 登 录 MySQL。 

(2) 查看 已 有 数据 库 并 连接 RCZP 数据 库 , 用 SQL 命令 查看 GWCJB 中 的 数据 。 

(3) 在 PHPMyAdmin 中 执行 SQL 语句 查看 GWB 中 的 数据 。 
三 、 任 务 分 析 

在 Windows 命令 行 中 运行 应 用 程序 MySQL. EXE 可 以 登录 MySQL ,该 程序 通常 存 
储 在 XAMPP 安装 文件 夹 下 。 如 果 XAMPP 安装 在 D:\XAMPP 文件 夹 中 , 则 MYSQL. 
EXE 保存 在 D: \XAMPP\ MYSQL\BIN 文件 夹 中 。 用 MySQL 数据 库 管理 工具 
PHPMyAdmin 主 界面 中 的 SQL 选项 卡 同样 能 执行 SQL 语句 完成 数据 操作 。 
四 、 预 备 知 识 


1. 命令 行 方式 登录 MySQL 
在 Windows 命令 行 输 入 如 下 命令 并 按 Enter 键 即 可 进入 MySQL。 


mysql -hlocalhost -uroot -P 


其 中 参数 -h 指出 要 登录 的 主机 ,其 后 的 localhost 为 本 机 服务 名 称 ;-u 用 于 指出 登录 的 用 
户 名 ,如 root;-p 参数 在 程序 执行 时 提示 输入 登录 密码 ,在 提示 信息 “Enter password:” 后 
输入 登录 密码 , 按 Enter 键 即 可 进入 MySQL 。 


2. 在 PHPMyAdmin 中 使 用 SQL 命令 


打开 XAMPP 控制 面板 , 单 击 MySQL 动作 按钮 组 中 的 Admin 按钮 ,在 打开 页 面 的 
登录 框 中 输入 用 户 名 (如 root) 及 密码 ,登录 PHPMyAdmin 主页 。 在 PHPMyAdmin 主 
页 中 , 单 击 “选择 导航 ?面板 中 要 操作 的 数据 库 ( 如 RCZP) , 单 击 SQL 选项 卡 打 开 SQL 语 
句 编辑 界面 ,输入 SQL 语句 后 , 单 击 界面 右 下 角 的 “执行 ”按钮 执行 输入 的 SQL 语句 。 


3. 退出 MySQL 
在 MySQL 命令 行 中 ,输入 命令 Quit 或 Exit 并 按 Enter 键 即 可 退出 MySQL。 在 
PHPMyAdmin 中 无 须 退出 ,直接 执行 其 他 操作 即 可 。 


五 、 技 能 点 


(1) 连接 MySQL。 以 命令 行 方式 连接 MySQL 服务 器 。 
(2) 使 用 MySQL。 执 行 SQL 语句 完成 MySQL 数据 库 的 各 种 操作 。 
(3) 断 开 MySQL。 关 闭 MySQL 操作 界面 。 


六 、 注 意 事项 


(1) 当 运 行 应 用 程序 MYSQL. EXE 时 ,参数 -hlocalhost 可 以 省 略 ,默认 本 地 计算 机 
为 主机 ;用 户 名 和 密码 中 的 英文 字母 区 分 大 小 写 。 

(2) MySQL 语句 中 的 单词 或 短语 ,英文 字母 不 区 分 大 小 写 , 每 条 命令 均 以 分 号 ";” 结 
尾 , 且 按 Enter 键 后 开始 执行 。 命 令 中 出 现 的 所 有 符号 (包括 空格 ) 一 律 使 用 半角 方式 。 





七 、 实 验 步骤 


1. 命令 行 方式 打开 MySQL 


单 击 Windows“ 开 始 "按钮 ,在 开始 菜单 的 搜索 框 中 输入 cmd 后 按 Enter 键 ,系统 进 
入 Windows 命令 行 ,执行 的 命令 和 系统 输出 结果 如 图 2-1 所 示 。 


2. 连接 RCZP 数据 库 并 查看 GWCJB 中 的 内 容 
在 MySQL 提示 符 “mysql 二 ”后 输入 如 下 命令 ,运行 结果 如 图 2-2 所 示 。 
show databases; 
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输出 结果 行 

















图 2-1 MySQL 客户 端 界面 


输出 结果 行 











图 2-2 在 MySQL 中 查看 数据 库 
输入 如 下 命令 查看 gwcjb 中 存储 的 数据 ,运行 结果 如 图 2-3 所 示 。 


Use rczp; 


select * from gwcjb; 


3. 在 PHPMyAdmin 中 使 用 SQL 语句 操作 MySQL 数据 库 


(1) 启动 PHPMyAdmin 主页 面 。 在 XAMPP 控制 面板 中 单 击 MySQL 动作 按钮 组 
中 的 Admin 按钮 ,在 打开 页 面 的 登录 框 中 输入 用 户 名 (如 root) 和 密码 , 单 击 “ 执 行 ” 按 钮 
打开 PHPMyAdmin 的 主页 面 

(2) 选择 要 操作 的 数据 库 。 单 击 PHPMyAdmin 主页 面 左 侧 导航 面板 中 的 RCZP 数 
据 库 。 
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输出 结果 行 
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(3) 打开 SQL 语句 输入 界面 。 


所 示 ) ,在 SQL 语句 输入 窗口 
Select * 


from gwb 


SQL 


选项 卡 





在 MySQL 中 查看 gwcjb 结果 


单 击 SQL ; 
中 输入 如 下 命令 





页 卡 ,打开 SQL 查询 输入 界面 (如 图 2-4 





SQL 语句 输入 窗口 
| 

































@ 如 https//iocalhost 让 localhost /127.001/ re 
文件 日 ”编辑 (E) ”前 看 (V) ”收藏 大 (A 
rl 
php [3 HL A 
本 结构 sat 内 理 盐 SA 所 作 权限 | 更 多 
最 近 使 用 v] 在 数据 库 rczp 运行 SQL 查询 : 
十 
+ 
En | 
将 此 SQL 查 油 h0 为 书 符 | 
| 
[请 可 定 男生 ] 器 在 此 膝 炊 呈 示 此 查 词 口 保留 让 | 
v| 
| - | 
J 











导航 面板 。 语句 定 界 符 


， 输 入 的 SQL 语句 


SQL 语句 “执行 ”按钮 


未 书写 分 号 时 系统 自动 添加 


图 2-4 


PHPMyAdmin 中 SQL 命令 输入 界面 
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(4) 执行 SQL 语句 。 单 击 SQL 选项 卡 界面 右 下 角 的 “执行 ”按钮 ,命令 执行 结果 如 
图 2-5 所 示 。 
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查询 结果 


图 2-5 PHPMyAdmin 中 SQL 命令 执行 结果 


八 、 思 考题 


(1) 如 何 启动 MySQL? 与 可 视 化 操作 风格 相 比 其 具有 哪些 特点 ? 
(2) 在 MySQL 中 输入 命令 后 按 Enter 键 开 始 执 行 ,输入 命令 有 哪些 语法 要 求 ? 


2.2 设计 图 书 数据 库 及 其 
一 、 实 验 目的 

了 解数 据 库 及 数据 表 的 设计 思路 ,掌握 在 MySQL 中 建立 数据 库 及 数据 表 的 方法 。 
二 、 实验 任务 


(1) 设计 wssd 数据 库 , 包 含 tsb( 图 书 表 ) .lbb( 类 别 表 ) .cbsb( 出 版 社 表 ) 、hyb (会 员 
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表 ) 和 ygxsb( 预 购销 售 表 )5 个 数据 表 的 结构 。 

(2) 在 MySQL 中 建立 wssd 数据 库 及 其 中 的 5 个 数据 表 结 构 。 

(3) 在 PHPMyAdmin 中 建立 订单 信息 视图 ,用 来 显示 每 笔 订单 的 预购 单 号 .书号 、 
书 名 、 印 次 、 预 购 日 期 . 册 数 、 售 价 、 会 员 账 号 和 付款 标记 。 


三 、 任 务 分 析 


wssd 数据 库 使 用 tsb( 图 书 表 ) 保 存 图 书信 息 ,管理 图 书 需 要 用 到 lbb( 图 书 类 别 表 ) 和 
cbsb( 出 版 社 表 ),hyb( 会 员 表 ) 用 于 保存 会 员 的 基本 资料 ,会 员 购买 的 图 书信 息 保 存 
在 ygxsb( 预 购销 售 表 ) 中 ,通过 统计 分 析 会 员 的 购买 记录 可 以 确定 会 员 的 购买 兴趣 点 ,从 
而 更 好 地 为 会 员 推送 其 可 能 感 兴 趣 的 新 书 。wssd 数据 库 中 的 实体 及 其 联系 如 图 2-6 
所 示 。 



























































出 版 社 表 
出 版 社 编码 
一 下 时 图 书 表 
书号 类 别 编码 
预购 销售 表 图 书 类 别 表 




















图 2-6 网 上 书店 数据 库 中 的 实体 及 其 关联 


针对 以 上 分 析 ,设计 各 数据 表 的 结构 ,如 表 2-1 一 表 2-5 所 示 。 








表 2-1 lbb 的 结构 
字段 名 称 数据 类 型 字段 大 小 其 他 设计 说 明 
类 别 编码 Char 2 
类 别名 称 Varchar 30 


表 2-2 cbsb 的 结构 























字段 名 称 数据 类 型 字段 大 小 其 他 设计 说 明 
出 版 社 编码 Char 5 
出 版 社 名 称 Varchar 30 
表 2-3 tsb 的 结构 
字段 名 称 数据 类 型 字段 大 小 其 他 设计 说 明 
类 别 编码 Char 2 
书号 Char 30 
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字段 名 称 数据 类 型 字段 大 小 其 他 设计 说 明 
书 名 Varchar 60 
版 次 Char 2 
印 次 Char 2 
印 次 日 期 Date 
出 版 社 编码 Char 5 
译 著者 Varchar 30 
定价 Doutte 11 | 可 总和 度 7 位 ,个 二 后 保留 1 他 
折扣 率 Int 3 
表 2-4 ygxsb 的 结构 
字段 名 称 数据 类 型 字段 大 小 其 他 设计 说 明 
预购 单 号 Int 11 NOT NULL AUTO_INCREMENT 
书号 Char 30 
印 次 Char 
预购 日 期 Date 
册 数 Int 5 
售 价 Real 7,1 
会 员 账 号 Char 10 
付款 标记 Tinyint 1 初 值 0 表示 未 付款 
a 
目前 状态 Enum 初 值 0 表示 没 发 送 ;1 表示 取消 ;2 表 
示 在 途 ;3 表示 签收 ;4 表示 退货 
表 2-5 hyb 的 结构 
字段 名 称 数据 类 型 字段 大 小 其 他 设计 说 明 
会 员 账 号 char 10 NOT NULL 
姓名 Char 10 
性 别 Enum 42 初 值 。1 表示 男 ;2 表示 女 
通信 地 址 Char 50 
邮政 编码 Char 6 
Email 账号 Varchar 30 
QQ 账号 Varchar 30 
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续 表 























字段 名 称 数据 类 型 字段 大 小 其 他 设计 说 明 
办 公 电 话 Char 20 
移动 电话 Char 12 
累计 购书 金额 Double 8,1 每 千 元 增加 1% 折 扣 , 但 最 低 到 60% 
累计 购书 数量 Int 7 
最 近 购 书 日 期 Date 用 于 清理 过 期 会 员 
密码 Varchar 32 
角色 char 1 0 普通 用 户 ,1 系统 管理 员 





四 、 预 备 知识 


1. 在 MySQL 中 建立 数据 库 








在 MySQL 中 用 Create Database 命令 创建 数据 库 , 其 命令 格式 如 下 : 


Create Database < 数据 库 名 称 > [ Default Charset< 字 符 集 >] [ Collate < 整理 名 称 > ] ; 


其 中 短语 Default Charset 二 字符 集 二 用 于 指定 数据 库 所 使 用 的 字符 集 , 如 使 用 
UTF-8 字符 集 , 则 短语 为 Default Charset utf8。Collate 参数 用 于 确定 数据 库 的 整理 规则 
( 即 排序 规则 ) ,如 使 用 UTF-8 简体 中 文 排序 规则 ,其 格式 为 Collate utf8_general_ci。 

数据 库 创 建 完成 后 使 用 show databases 命令 查看 系统 中 的 数据 库 , 使 用 use 二 数据 
库 名 二 命令 打开 数据 库 。 


2. 在 MySQL 中 建立 数据 表 


在 MySQL 中 使 用 命令 Create Table 建立 数据 表 , 其 命令 格式 如 下 :; 


Create Table [If Not Exists] < 表 名 称 > 
(< 字段 名 1>< 数 据 类 型 > [ [Not] Nu11] 
[Default < 常数 >] [Auto_Increment] [Primary Key] 


[< 字段 名 n>< 数 据 类 型 > [ [Not] Nu11]] 
[, Primary Key (< 主 属性 字段 名 表 >)] 
[, [Constraint < 外 键 名 1>] Foreign Key (< 外 键 字段 名 1>) 


References < 关联 表 名 1> (< 关联 字段 名 1>) 


[on Delete < 约束 规则 >] [on Update < 约束 规则 > ] 


[, [Constraint < 外 键 名 m>] Foreign Key (< 外 键 字段 名 m>) 


References < 关联 表 名 m> (< 关联 字段 名 m>) 


[on Delete < 约束 规则 >] [on Update < 约束 规则 >]]] 
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五 、 技 能 点 


(1) 建立 数据 库 。 用 Create Database 命令 建立 数据 库 。 

(2) 查看 数据 库 。 用 Show Databases 命令 查看 数据 库 。 

(3) 选择 当前 数据 库 。 用 Use 二 数据库 名 称 志 命令 选择 当前 数据 库 。 
(4) 创建 数据 表 结构 。 用 Create Table 命令 建立 数据 表 结 构 。 


六 、 注 意 事 项 


(1) 用 命令 方式 创建 数据 库 或 数据 表 ,操作 成 功 后 所 建 的 内 容 即 已 存在 , 故 对 应 的 命 
令 不 能 反复 执行 。 为 避免 命令 重复 执行 出 错 , 可 在 数据 库 或 数据 表 名 前 添加 短语 if Not 
exists。 


(2) 输入 命令 时 ,命令 中 出 现 的 英文 字母 不 区 分 大 小 写 ,命令 使 用 分 号 作为 结束 。 
七 、 实 验 步 又 


1. 创建 数据 库 


单 击 Windows“* 开 始 ” 按 钮 ,在 开始 菜单 的 搜索 框 中 输入 cmd 后 按 Enter 键 ,系统 进 
入 Windows 命令 行 , 在 命令 行 中 依次 输入 如 下 命令 并 按 Enter 键 : 


ad: 
cd \xampp\mysql\bin 
mysql -uroot -p 


输入 root 用 户 的 登录 密码 后 进入 MySQL ,在 MySQL 提示 符 “mysql 二 ”后 输入 如 下 
命令 建立 数据 库 ,并 查看 系统 中 的 数据 库 : 


create database wssd Default charset UTF8 Collate Utf8 General ci; 


Show databases; 


2. 创建 数据 表 

在 MySQL 提示 符 “mysql>” 后 输入 如 下 命令 选择 wssd 数据 库 为 当前 数据 库 ， 
use wssd; 

在 MySQL 提示 符 “mysql 二 ”后 输入 如 下 命令 建立 lbb: 


create table if not exists lbb (类 别 编码 char (2) primary key, 类 别名 称 varchar 
(30) ) 7 


在 MySQL 提示 符 “mysql 二 ”后 输入 如 下 命令 建立 cbsb: 
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create table if not exists cbsb (出 版 社 编码 char (5) Primary key, 出 版 社 名 称 varchar 
(30)); 


在 MySQL 提示 符 “mysql 二 ”后 输入 如 下 命令 建立 tsb: 


create table if not exists tsb (类 别 编码 char (2) ,书号 char (30) , 书 名 varchar (60) ,版 
次 char (2) , 印 次 char (2) , 印 次 日 期 date, 出 版 社 编码 char (5), 译 著者 varchar (30) ,定价 
double (7,1) ,折扣 率 int (3) ,primary key (书号 , 印 次 )); 


3. 在 PHPMyAdmin 中 使 用 SQL 命令 建立 数据 表 


打开 PHPMyAdmin 主页 面 , 单 击 导航 面板 中 的 wssd 数据 库 , 单 击 SQL 选项 卡 ,在 
SQL 语句 输入 窗口 中 输入 如 下 语句 后 , 单 击 “ 执 行 ” 按 钮 ,创建 ygxsb( 预 购销 售 表 )。 


create table if not exists ygxsb (预购 单 号 int (11) not null auto _ increment 
primary key, 

书号 char (30), 印 次 char (2) ,预购 日 期 date, 册 数 int (5), 售 价 double (7,1)， 

会 员 账 号 char (10) ,付款 标记 tinyint (1) default 0， 

目前 状态 enum('0','1','2','3','4') default '0'); 
同样 方式 在 SQL 语句 输入 窗口 中 输入 如 下 语句 , 单 击 “ 执 行 ”按钮 后 创建 hyb (会 

员 表 ) 。 

Create Table if not exists hyb (会 员 账 号 char (10) not null primary key, 姓 名 char 
(10) ,性别 enum('1','2') default '1' ,通信 地 址 char (50), 邮 政 编码 char (6)， 

Email 账号 varchar (30), 09 账号 varchar (30) ,办公 电话 char (20), 移 动 电话 char 
(12) ,累计 购书 金额 double (8,1) ,累计 购书 数量 int (7) ,最 近 购 书 日 期 date， 

密码 varchar (32) ,角色 char (1)); 


4. 在 PHPMyAdmin 中 使 用 SQL 命令 建立 视图 
打开 PHPMyAdmin 主页 面 , 单 击 导 航 面板 中 的 wssd 数据 库 , 单 击 SQL 选项 卡 , 在 
SQL 语句 输入 窗口 中 输入 如 下 语句 后 , 单 击 “ 执 行 ”按钮 ,创建 订单 统计 视图 。 


Create View 订单 信息 As select 预购 单 号 , ygxsb .书号 as 书号 , 书 名 ， 
Ygxsb. 印 次 As 印 次 ,预购 日 期 , 册 数 , 售 价 , 会 员 账 号 , 付款 标记 
From (ygxsb Join tsb On(((ygxsb .书号 =tsb. 书 号 ) And (ygxsb. 印 次 =tsb. 印 次 )))) 
单 击 PHPMyAdmin 导航 面板 中 的 wssd, 在 “结构 ”选项 卡 中 单 击 订单 信息 视图 行 中 
的 “浏览 ”项 可 以 查看 订单 信息 ; 单 击 订单 信息 视图 行 中 的 “结构 ”项 ,可 以 查看 视图 的 
结构 。 


八 、 思 考题 


(1) 用 MySQL 创建 数据 库 及 数据 表 与 用 PHPMyAdmin 可 视 化 操作 风格 完成 操作 
有 哪些 不 同 ? 
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后) 


(2) 用 Create Table 命令 创建 数据 表 ,命令 在 书写 时 有 哪些 格式 上 的 要 求 ? 
(3) 会 员 欲 购买 的 图 书 在 当前 tsb 中 不 存在 ,如 何 完善 wssd 数据 库 的 结构 使 之 能 够 


2.3 规划 用 户 及 其 权限 


一 、 实 验 目 的 


了 解 MySQL 中 用 户 和 用 户 权限 的 基本 概念 ,能够 使 用 Grant 语句 及 PHPMyAdmin 
等 工具 对 用 户 进行 数据 库 ,数据 表 和 查询 等 内 容 的 权限 分 配 。 


二 、 实验 任 务 


(1) 设计 系统 管理 员 用 户 ,其 用 户 名 为 xtgly ,为 其 分 配 wssd 数据 库 的 全 部 权限 。 

(2) 设计 业务 员 用 户 ,其 用 户 名 为 xtywy, 其 可 以 查看 ygxsb 中 的 图 书 订 购 信 息 , 浏 
览 hyb 中 会 员 的 个 人 资料 ,维护 tsb、lbb 及 cbsb 中 的 数据 。 

(3) 设计 会 员 用 户 , 其 用 户 名 为 2201010001, 可 以 查看 tsb 中 图 书信 息 , 在 ygxsb 中 
新 建 订单 .修改 订单 及 查看 自己 的 历史 订单 ,在 hyb 中 查看 、 修 改 自己 的 会 员 资料 。 


、 任 务 分 析 


在 MySQL 中 使 用 命令 Create User 创建 用 户 ,使 用 命令 Grant 为 所 创建 的 用 户 分 配 
数据 库 应 用 权限 。 在 PHPMyAdmin 等 管理 工具 中 通过 可 视 化 操作 同样 能 够 创建 用 户 及 
为 用 户 分 配 数据 库 的 使 用 权限 。 


四 、 预 备 知识 


1. 用 Create User 命令 创建 用 户 


对 于 新 安装 的 MySQL 服务 器 ,系统 自动 创建 了 默认 名 为 root 的 用 户 ,root 用 户 可 
以 完全 控制 MySQL 数据 库 ,具有 操作 和 管理 MySQL 数据 库 的 全 部 权限 。 

系统 中 的 其 他 用 户 需要 建立 ,用 户 名 中 的 英文 字母 区 分 大 小 写 , 用 户 名 、 密 码 等 相关 
信息 自动 存储 到 MySQL 数据 库 的 User 表 中 。 建 立 用 户 的 命令 格式 如 下 : 


ll 


create user 'username'@'host' identified by 'password'; 


其 中 username 为 新 建 用 户 名 ;host 用 于 指定 该 用 户 登 录 的 主机 ,如 果 是 本 地 用 户 , 可 用 
localhost 作为 主机 名 ,如 果 人 允许 新 建 用户 在 任意 远程 主机 登录 ,可 以 使 用 通配符 “%”; 
password 为 新 建 用 户 的 登录 密码 ,密码 可 以 为 空 , 如 果 为 空 , 则 该 用 户 登 录 服 务 器 不 需要 
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输入 密码 。 
2. 用 Grant 命令 为 用 户 分 配 权 限 
在 MySQL 中 ,可 以 运行 Grant 语句 为 用 户 进行 授权 ,其 语句 格式 如 下 : 


Grant < 权限 名 称 1> [ (< 字段 名 表 1>)] 
[,…,< 权 限 名 称 n> [< (字段 名 表 n)>]] 
on < 对 象 范围 > 
To < 用 户 名 1> [Identified By < 密码 1> ] [e< 主 机 名 1>] 
[,…,< 用 户 名 n> [Identified By < 密码 n>] [@< 主 机 名 n>]] 


权限 名 称 请 参考 主教 材 第 3 章 中 的 表 3-1。 


五 、 技 能 点 


(1) 创建 用 户 。 用 Create User 命令 或 在 PHPMyAdmin 中 使 用 可 视 化 操作 实现 用 
户 的 创建 。 

(2) 分 配 用 户 权 限 。 用 Grant 命令 或 在 PHPMyAdmin 中 使 用 可 视 化 操作 实现 用 户 
权限 分 配 。 


六 、 注 意 事项 

(1) 用 户 隶 属于 主机 ,其 可 以 使 用 系统 中 的 多 个 数据 库 , 用 户 名 和 密码 中 的 英文 字母 
均 区 分 大 小 写 。 

(2) 在 PHPMyAdmin 主页 中 使 用 "用户 ?选项 卡 管理 用 户 权限 。 单 击 用 户 行 中 的 “ 编 


辑 权 限 ” 选 项 打开 “编辑 权限 ”页面 ,其 中 “全 局 权限 ”的 操作 对 象 为 本 地 全 部 数据 库 ;* 按 数 
据 库 指定 权限 ?可 针对 某 数据 库 设 置 操作 权限 ,设置 完成 后 单 击 * 执 行 " 按 钮 保存 设置 。 


七 、 实 验 步骤 


1. 用 命令 方式 创建 xtgly 用 户 并 为 其 分 配 权限 
单 击 Windows“* 开 始 "按钮 ,在 开始 菜单 的 搜索 框 中 输入 cmd 并 按 Enter 键 ,系统 进 
入 Windows 命令 行 ,在 命令 行 中 依次 输入 如 下 命令 并 按 Enter 键 : 


ad: 
cd \xampp\mysql\bin 
mysql -uroot -p 


输入 root 用 户 的 登录 密码 后 进入 MySQL。 在 MySQL 提示 符 “mysql 二 ”后 输入 如 
下 命令 创建 xtgly 用 户 并 为 其 分 配 权限 : 


create user'xtgly'@'localhost' identifiedby '1324'; 
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grant all on wssd.* to xtgly; 


2. 在 PHPMyAdmin 中 创建 xtywy 用 户 并 为 其 分 配 权限 


(1) 打开 PHPMyAdmin 主页 面 。 打 开 XAMPP 控制 面板 , 单 击 MySQL 动作 按钮 
组 中 的 Admin 按钮 ,在 打开 页 面 的 登录 框 中 输入 用 户 名 (如 root) 和 登录 密码 , 单 击 “ 执 
行 ”" 按 钮 登录 PHPMyAdmin 主页 面 。 

(2) 建立 用 户 。 在 PHPMyAdmin 主页 面 中 单 击 用 户 选 项 卡 , 单 击 用 户 概况 表格 下 
方 的 “添加 用 户 ? 项 ,在 图 2-7* 添 加 用 户 ” 界 面 中 输入 新 建 “用 户 名 ”为 xtywy,“ 主 机 ”为 
localhost, 输 入 用 户 密码 (如 1234) 及 确认 密码 , 单 击 * 执 行 ?按钮 。 
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图 2-7 在 PHPMyAdmin 中 添加 用 户 


(3) 为 xtywy 分 配 权限 。 单 击 “ 用 户 ” 选 项 卡 xtywy 用 户 行 中 的 “编辑 权限 "项, 单 击 
“ 按 数据 库 指定 权限 ”页 框 “在 下 列 数 据 库 添加 权限 "后 的 组 合 框 ,选择 数据 库 wssd, 在 给 
出 的 页 面 中 单 击 “ 按 表 指 定 权限 ”页 框 * 在 下 列 数 据 表 添加 权限 ”后 的 组 合 框 ,选中 tsb, 在 
图 2-8 中 分 配 xtywy 用 户 对 tsb 的 操作 权限 , 单 击 “ 执 行 ” 按 钮 确认 权限 。 

(4) 同样 方式 为 其 他 表 分 配 权限 。 根 据 要 求 ,为 xtywy 用 户 分 配 了 1lbb、cbsb 和 tsb 
的 select ,insert .update、delete 和 index 权限 ,为 hyb 和 ygxsb 分 配 了 select 权限 。 选 择 
“用 户 ” 选 项 卡 xtywy 用 户 行 中 的 “编辑 权限 ”项 一 “ 按 数据 库 指定 权限 "页 框 中 的 “编辑 权 
限 ”, 页 面 显示 已 分 配 权限 ,如 图 2-9 所 示 。 


3. 在 PHPMyAdmin 中 创建 2201010001 用 户 并 为 其 分 配 权限 


在 PHPMyAdmin 中 创建 2201010001 用 户 ,设置 其 登录 密码 为 7854, 为 其 分 配 wssd 
数据 库 中 tsb 的 select 权限 、ygxsb 中 的 insert、update 权限 ,方法 同上 。 
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加 数据 库 加 SQL 二 状态 号 用 户 如 导出 局 SA 凡 设 村 上 和 制 更 多 


编辑 权限 : 用 户 xtywy'@'localhost'- 数据 库 wssd - 表 tsb 
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【数据 库 jwssd; 辣 构 ][ 表 tsb: 浏览 ] 











选中 权限 ”选中 对 应 权限 可 操作 的 字段 
图 2-8 在 PHPMyAdmin 中 为 用 户 分 配 表 权限 








六 | 拉夫 押宝 限 上 一 


表 ”权限 授权 按 字 段 指定 权限 操作 

cbsb SELECT, INSERTI, UPDATE, DELETE, INDEX 否 是 居 编辑 权限 名 茹 消 
hyb ”SELECT 否 本 已 编 辑 权限 名 系 销 
lbb SELECT, INSERT, UPDATE, DELETE, INDEX 否 否 旋 编辑 权限 妃 茹 消 
tsb SELECT, INSERT, UPDATE, DELETE, INDEX 否 否 已 编辑 权限 岛 茹 销 
ygxsb SELECT 和 否 竺 总 编辑 权限 岛 茹 消 


在 下 列 数据 表 添 加 权限 ;| 使 用 文本 域 回 || 
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图 2-9 xtywy 用 户 分 配 的 表 权限 


由 于 2201010001 用 户 为 会 员 用 户 , 其 只 能 查看 hyb 中 的 个 人 资料 、ygxsb 中 的 个 人 
订单 ,因此 设计 视图 实现 表 中 数据 的 选择 控制 ,之 后 分 配 用 户 的 视图 权限 。 

单 击 PHPMyAdmin 主页 导航 面板 中 的 wssd 习 单 击 SQL 选项 卡 , 在 SQL 编辑 窗 中 
输入 如 下 SQL 语句 , 单 击 “ 执 行 ”按钮 创建 视图 hyb_view。 

Create View hyb view as 

select * from hyb where hyb.' 会 员 账号 '=substring index(user(),'@',1); 

语句 中 user() 函 数 返 回 系统 当前 登录 的 用 户 名 (如 : 2201010001 @ localhost)， 
substring_index() 函 数 用 来 截取 第 一 次 出 现 的 @ 字 符 之 前 的 内 容 ( 即 2201010001), 视 图 
仅 显示 hyb 中 当前 登录 用 户 名 的 资料 。 

同样 方法 输入 如 下 ygxsb 的 视图 语句 ,将 该 视图 保存 为 ygxsb_view。 
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Create View ygxsb view as 


select * from ygxsb where ygxsb.' 会 员 账 号 '=substring index(user(),'@',1); 


在 PHPMyAdmin 中 为 用 户 2201010001 添加 权限 ,选择 wssd 数据 库 , 在 数据 表 选 择 时 
直接 选中 对 应 的 视图 文件 ,为 其 分 配 权 限 select、update 后 单 击 “ 执 行 ” 按 钮 保存 权限 设置 。 


八 、 思 考题 


(1) 能 和 否 为 一 个 用 户 分 配 多 个 数据 库 的 操作 权限 ? 用 户 操作 权限 的 设置 通常 以 什么 
标准 作 人 参考? 
(2) 若 系统 提供 用 户 注 册 功 能 ,程序 中 该 如 何 为 用 户 分 配 权限 ? 


2.4 设计 表 间 关联 及 其 参照 完整 性 


一 、 实 验 目 的 

学 习 设计 数据 库 的 基本 过 程 , 了 解 表 间 关 联 的 作用 ,掌握 在 MySQL 中 建立 关联 的 
方法 。 
二 、 实验 任 务 


(1) 为 tsb( 图 书 表 ) 与 cbsb( 出 版 社 表 ) 建 立 关联 ,连接 字段 为 出 版 社 编码 。 
(2) 为 tsb( 图 书 表 ) 与 lbb( 类 别 表 ) 建 立 关 联 ,连接 字段 为 类 别 编码 。 

(3) 为 ygxsb( 预 购销 售 表 ) 与 tsb( 图 书 表 ) 建 立 关联 ,连接 字段 为 书号 。 

(4) 为 ygxsb( 预 购销 售 表 ) 与 hyb( 会 员 表 ) 建 立 关联 ,连接 字段 为 会 员 账 号 。 


三 、 任务 分 析 


在 数据 库 中 为 数据 表 建 立 关联 ,通常 是 在 数据 表 的 设计 过 程 中 完成 的 ,其 顺序 为 先 建 
立 父 表 , 之 后 建立 子 表 时 直接 指定 与 父 表 的 关联 关系 。 若 不 考虑 数据 表 间 的 关联 ,在 数据 
库 及 数据 表 已 经 建立 完成 的 情况 下 ,可 以 在 PHPMyAdmin 中 建立 关联 ,也 可 以 在 
MySQL 中 用 Alter Table 命令 修改 表 结 构 , 从 而 建立 数据 表 间 的 关联 。 


四 、 预 备 知识 


1. 关联 


所 谓 关 联 操 作 , 就 是 在 操作 一 个 表 中 的 数据 时 ,可 以 引用 或 输入 、 修 改 其 他 表 中 的 数 
据 。 例 如 ,删除 hyb 中 的 数据 时 ,其 在 ygxsb 中 对 应 的 图 书 订购 信息 自动 删除 。 同 样 , 输 
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入 ygxsb 中 的 图 书信 息 时 ,其 书号 应 该 是 tsb 中 存在 的 书号 。 
2. 建立 数据 表 间 关联 的 命令 
通过 SQL 的 Alter Table 命令 可 以 为 数据 表 建 立 关 联 , 其 命令 格式 如 下 : 


Alter Table < 表 名 >Adq Constraint < 外 键 名 >Foreign Key (< 字段 名 >) 
References < 关联 表 名 > (< 关联 字段 名 >) 
[on Delete < 约束 规则 >] [On Update < 约束 规则 >] 


其 中 ,二 外 键 名 二 为 关联 的 名 称 , 用 于 区 分 不 同 的 关联 ,Foreign Key 后 为 父 表 中 的 关联 
字段 名 ,一 关联 表 名 二 为 子 表 表 名 ,关联 字段 名 为 子 表 中 用 于 关联 的 字段 名 。 


3. On Delete 的 约束 规则 


删除 数据 记录 的 约束 规则 (On Delete) 是 指 删 除 父 表 中 的 数据 记录 时 应 该 遵循 的 约 
束 规则 。 有 如 下 选项 : 

(1) Cascade( 级 联 )。 删 除 父 表 (如 tsb) 中 的 数据 记录 时 ,系统 自动 删除 子 表 ( 如 
ygxsb) 中 相关 联 的 记录 。 所 谓 关 联 记 录 就 是 父 表 中 关联 字段 与 子 表 外 键 值 相等 的 记录 。 
例如 ,在 tsb 表 中 删除 书号 为 978-7-04-041372-4、 印 次 为 1 的 图 书记 录 时 ,系统 自动 删除 
ygxsb 中 书号 为 978-7-04-041372-4、 印 次 为 1 的 全 部 记录 。 

(2) No Action 或 Restrict( 限 制 )。 不 能 删除 与 子 表 中 记录 存在 关联 的 父 表 中 的 记 
录 。 也 就 是 说 ,删除 父 表 中 记录 的 条 件 是 子 表 中 一 定 没 有 与 之 相关 联 的 记录 。 例 如 ,如 果 
子 表 ygxsb 中 有 书号 为 978-7-04-041372-4 的 记录 , 则 不 能 删除 父 表 tsb 中 书号 为 978-7- 
04-041372-4 的 记录 。 

(3) Set Null( 置 空 )。 删 除 父 表 中 的 数据 记录 时 ,系统 自动 将 子 表 中 相关 联 记 录 外 键 
字段 的 值 填 成 Null。 这 就 要 求 子 表 中 的 外 键 字段 必须 允许 Null。 


4. On Update 的 约束 规则 


更 新 (修改 数据 记 录 的 约束 规则 (On Update) 是 指 修改 父 表 中 的 数据 记录 时 ,系统 
应 该 遵循 的 约束 规则 。 有 如 下 选项 ， 

(1) Cascade( 级 联 )。 修 改 父 表 (如 tsb) 中 关联 字段 值 (如 书号 ) 时 ,系统 自动 更 新 子 
表 ( 如 ygxsb) 中 关联 记录 外 键 字段 的 值 ( 如 书号 )。 例 如 ,在 tsb 中 ,将 书号 978-7-04- 
041372-4 改 为 978-7-04-041372-5 时 ,系统 自动 将 ygxsb 表 中 关联 记录 的 书号 均 改 为 978- 
7-04-041372-5。 

(2) No Action 或 Restrict( 限 制 )。 对 子 表 中 存在 关联 记录 的 父 表 记录 ,不 能 修改 其 
关联 字段 的 值 。 例 如 ,如 果子 表 ygxsb 中 有 书号 为 978-7-04-041372-5 的 图 书 销售 信息 ， 
则 不 能 将 父 表 tsb 中 书号 978-7-04-041372-5 的 图 书 改 成 其 他 书号 。 

(3) Set Null( 置 空 )。 修 改 父 表 中 关联 字段 的 值 时 ,自动 将 子 表 中 关联 记录 外 键 字段 
的 值 填 成 Null( 此 字段 必须 允许 Null)。 
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五 、 技 能 点 


建立 关联 。 用 命令 Alter Table 实现 数据 表 间 关联 的 建立 。 
六 、 注 意 事项 


(1) 建立 数据 表 间 关联 是 数据 表 设 计 的 内 容 , 通 常 在 数据 表 的 规划 阶段 确定 关联 字 
段 及 删除 和 更 新 规则 。 

(2) 车 设计 数据 库 时 未 设置 数据 表 间 的 关联 ,在 数据 表 已 经 输入 记录 信息 后 建立 关 
联 则 需要 表 中 数据 相 容 ,否则 无 法 建立 关联 。 

(3) 关联 建立 完成 后 ,可 在 表 中 进行 数据 记录 操作 时 验证 关联 的 作用 和 意义 。 


七 、 实 验 步 又 


1. 进入 MySQL 
单 击 Windows“* 开 始 ” 按 钮 ,在 “开始 ”菜单 的 搜索 框 中 输入 cmd 并 按 Enter 键 ,系统 
进入 Windows 命令 行 , 在 命令 行 中 依次 输入 如 下 命令 并 按 Enter 键 : 


ad: 
cd \xampp\mysql\bin 
mysql -uroot -p 


输入 root 用 户 的 登录 密码 后 进入 MySQL。 
2. 创建 数据 表 间 的 关联 


在 MySQL 提示 符 “mysql 二 ”后 依次 输入 如 下 命令 建立 tsb 与 cbsb ,tsb 与 lbb .ygxsb 
与 tsb 及 ygxsb 与 hyb 之 间 的 关联 。 
use wssd; 


Alter Table TSB add Constraint cbsbm Foreign Key (出 版 社 编码 ) 
References cbsb (出 版 社 编码 ) On Delete Restrict On Update Cascade; 


Alter Table TSB add Constraint lbbm Foreign Key (类 别 编码 ) 
References lbb (类 别 编码 ) On Delete Restrict On Update Cascade; 


Alter Table YGXSB add Constraint shuhao Foreign Key (书号 ) 
References TSB (书号 ) On Delete Restrict On Update Cascade; 


Alter Table YGXSB add Constraint hyzh Foreign Key (会 员 账 号 ) 
References HYB (会 员 账 号 ) On Delete Cascade On Update Cascade; 
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在 MySQL 提示 符 “mysql 二 ”后 输入 exit 或 quit 并 按 Enter 键 ,关闭 MySQL 。 
八 、 思考 题 
(1) 为 相关 数据 表 建 立 表 间 关联 的 目的 有 哪些 ?删除 和 更 新 的 几 个 约束 规则 是 如 何 


影响 表 中 记录 操作 的 ? 
(2) 在 MySQL 中 如 何 删除 表 间 关联 ? 删除 表 间 关联 对 数据 表 有 直接 影响 吗 ? 


2.5 输入 售 书 数据 库 中 的 数据 
一 、 实 验 目的 


在 MySQL 中 根据 数据 库 中 表 的 关联 设计 确定 数据 的 输入 顺序 ,实现 数据 表 中 数据 
的 输入 。 


二 、 实验 任 务 


(1) 在 cbsb 中 输入 表 2-6 中 的 数据 。 
表 2-6 cbsb 表 中 增加 的 记录 














出 版 社 编码 出 版 社 名 称 出 版 社 编码 出 版 社 名 称 
04 高 等 教育 出 版 社 302 清华 大 学 出 版 社 
111 机 械 工业 出 版 社 5049 中 国 金融 出 版 社 
115 人 民 邮 电 出 版 社 5086 中 信和 出 版 社 
121 电子 工业 出 版 社 











(2) 在 lbb 中 输入 表 2-7 中 的 数据 。 
表 2-7 Ibb 表 中 增加 的 记录 











类 别 编码 类 别名 称 类 别 编码 类 别名 称 
Bo 哲学 理论 F8 金融 
FO 政治 学 T™ 自动 化 技术 ,计算 机 技术 
F4 工业 经 济 











(3) 在 tsb 中 输入 表 2-8 中 的 数据 。 
(4) 在 hyb 中 输入 表 2-9 中 的 数据 。 


第 2 单元 数据 库 管理 与 维护 ” (9) 






























































98 | se 超 款 踊 性 ' 甘 学 才 llf\(H)| 980S |to-t0-st0z| | 工 麻 志 与 衣 己 亲 一 禹 音 开 | S-2867-9809-4-846 | 0 
甘 韭 斗 鞋 ， 最 影 污 Re 要 -TZ73-980G-/- 
88 |8°68 差 且 奈 留 汪 由 .时 十 浙 9809 |to-tt-¥t0¢ | z | 工 潜 吉 器 但 况 二 镶 | 0-TZ4P-9806-4-846 | 04 
V6 | 6 | 对 蔬 胖 虫 巧 路 如 里 深 著 丑 曼 ， 下 | 980s |st-s0-st0z| s | 工 售 角 邳 重 与 入 六 册 书 晓 一 一 丛 妙 秋 则 | 0-P998-98098-4-846 | PI 
36 | 99 起 了 及 学 里 刀 虹 光 话 ，。 着 蝇 泊 | 9809 | ST-TIT-8T05 | 8 I 浪 湾 海 国米 再 天书 才 阳光 半 一 一 滥 湾 半 | 6-99T7-9809-4-846 | pd 
08 | 68 革 凡 作 贸 类 | 6V0s | To-zt-vtoz| | 工 种 野 握 并 赫 非 加 凋 | 6-99Tp-9809-4-846 | 8 了 
6 | 69 革 世 七 留 暑 | 6f09 | To0-zt-zt0z | 工 I J 入 六 笨 要 新 器 | 56-2694-6P08-4-846 | 84 
08 |98°9e 影 斑 零 庆 长 ' 葡 碌 王 | 6f09 | I0-60-II0z | T | 8 ( 病 三 名 ) 鼻 本 与 骆 稀 普 检 | 9-0699-6f09-/-846 | 8 
98 | Zp 暴 将 国 普 | z08 | I07o-froz| | 工 引 于 妥 阴 寿 洲 目 | 9-9809-6f09-4-846 | 0g 
99 |9'ee 此 可 硫 息 | 208 |T0-2t-tt0z| T | 8 ( 融 8 驴 ) 牙 缠 尘 怖 91seg lenstA | 6-90998-508-4-846 | dL 
08 | 8 虚 地 炭 禹 | 208 | I0-80-II0z | I I ( 痢 二 锚 ) 其 神 尘 融 ++9| 1-88PS2-208-4-846 | dL 
SL | 62 时 下 虹 融 | Z08 |0t-It-0T0Z | p | 长 视 尖 如 D| p-9pp22-208-4-846 | dL 
06 | 6 点 其 要 | TzT |0t-tt-st0z| 工 I 坚 之 暴 豆 网 着 互 | P-0YpL2-T2ZT1-L4-846 | 84 
88 | 99 里 兴 滞 淹 | TIZL |to-zt-stoz| 【| 工 ( 痪 且 味 ) 期 本 月 于 华 园 [Bax 了 | 1-2TpL2-121-4-846 | dL 
00I | op 时 工 最 翌 | SIT |0t-t0-9t02 | 工 I 彤 梁 款 于 投 可 有 殉 柜 寿 我 | 9-9S0TP-sT1-4-846 | 于 
00T | op 时 淹 翻 落 | SIT | I0-T0-9I0z | 工 I | 而 梁 与 如 澡 空 十 图 渔 互 辐 睹 不 此 琢 封 项 狂 | 2-L060P-STT-L-846 | PI 
当 因 隆 志 效 交 A K h 书 不 工 | eo- -11T-/-846 
06 | Sp 旷 王 价 洒 闭 ， 些 盏 浆 生 | III | 1020-sr2| 上 | 候 玫 不 工 况 团 入 胡 药 米 二 申 0 衬 不 工 | S-T9TLP-TTT-4-846 | PH 
98 | 66 对 时 团团 台 种 三 络 | TIT |8t-s0-zt0Z| 工 I 琳 六 盗 时 锚 上 共 视 尖顶 D| 0-p4088-TTT-L-846 | dL 
08 | 62 暴 涛 鲜 | IIT | 10-60-f00z | 工 I 时 瓣 环 闻 釜 莫 长 | 0-68Z81-TIT-L-846 | dL 
i 1 其 强 尘 融 旦 擅 ?Seg [enstA | 。， ed 
06 | 08 由 凡 中 并 年 娄 时 次 | Fo |to-zt-st0z| tT | 乔 凑 次 一 并 入 泥 此 外 督 并 国志 出 9102| 8-362TT0-704-846 | dL 
i 和 了 长 祖 当 娠 | ， 到 
SL | se 加 由 中 并 年 烽 量 次 | f0 | TI0-zLfroz| Tt | 工 县 姑 效 一 并 全 泥 总 性 冰 民国 专 贡 声 910z| 7-248TT0-T04-846 | dl 
境 刍 牙 昏 蜗 
者 二 切 展 毕 其 起 我 确 四 虹 日 况 遇 | 竣 申 | 竣 莘 区 和 牛 各 外 个 装 























次 也 朋 必 愤 中 华 qs! 8-Z 华 








(6@6) 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版) 



























































各 86f2 毕 半 了 兵 
gpeT|S0-0T-ST02| ZT 18 0f8|1992007f068T|9181989S8-T8f0 U9 "moo "euls 加 oq8uedz|ST008T 2 河 |Z000pOT02Z 
正中 类 并 易 料 旺 器 
大 各 6T 贡 了 商 | | 
8299|90-2T-ST0¢ 8 0425|17fT88T8fF098T|268868-T8f0| P6609TST oo "95T 加 auosuIfSuru |2T008T 内 [ | 泪 胜 沪 11000f01022 
宙 申 尖 计 昂 妾 时 
599y |5TI-TI-9T0z| ?9 0fZLU8TIT28SfT298T| 50208158-0T0| 5445LZT U9 “W109 "euIS 加 unftejlf8000T 全 88T2 好 二 5 屠 河 |Z000T0T02Z 
生 习 届 负 由 过 外 
Po84 |8T-T0-9T02| ?8 (6 “0Lpel 02F8LTLP88ST 512588882?8 oo "ndos 加 8T8oeUZ|21008T 人 名 8TST 音 视 IT | 和 中 嫂 |1000L01022 
带 中 芋 半 易 半 时 
各 1-8ZI 期 洲 惑 
0 0 |050078f098T|20205199S-TSf0| Z820L622P oo “8g9T DNBUuaBuoX |OTOOST 1 | 帮 兆 网 |2000I0T0TZ 
到 风 印 忠良 凡 区 
PT 
800L|10[I-I0-9102| 8 589[{|8988TSf0T8T|21898TS8-TS70| Z628LTLLP Woo 89T 外 quns | T1000ST 玫 急性 |1000I0T0T2 
习 生 于 中 滑 风 区 | 【 | 并 六 
?85T|195-25T-9102| 2T 0f88| S12688T0S8T| 92104289-0T0| f882082S9|m 工 oo oltqnduadp xaly | e8000T 台 6 单 三 人 LT | 游 拟 与 |1000IOTOTT 
于 到 台积电 妾 外 
故 卓 村 | 生 溢 中 加 要 中 鲁 叶 
蚀 外 员 审 极 (hy bo 各 潭 Tau 了 涯 全 其 伍 | 用 济 斩 学 
昌 | 全 型 千 册 站 时 审 作 且 | 类 了 yf | 各 尖 各 测 昌 于 “| 咯 科 | 区 利 | 各 测 可 学 


卷 乌 妥 几 屠 中 举 44qd 6-7 举 


7 


第 2 单元 数据 库 管 理 与 维护 


(5) 在 ygxsb 中 输入 表 2-10 中 的 数据 。 
表 2-10 ”ygxsb 表 中 增加 的 记录 






































预购 单 号 书号 印 次 | 预购 日 期 | 数量 | 售 价 | 会 员 账号 | 付款 标记 | 目前 状态 
1 978-7-115-40907-2 3 2015-12-20 20 | 45 | 2201010001 0 0 
2 978-7-115-41056-6 EL 2015-12-20 15 | 45 | 2201010001 0 0 
3 978-7-04-044295-3 和 2014-10-20 80 | 50 |22010140001 1 3 
4 978-7-5086-4937-5 1 2015-10-01 100 | 35 | 2201040001 1 3 
5 978-7-302-22446-4 1 2016-01-07 280 | 29 | 2101010001 1 3 
6 978-7-5086-4664-0 1 2015-11-03 1| 49 |2101010002 1 3 
学 978-7-5056-4664-0 2016-01-20 12 | 49 | 2201010002 0 
8 978-7-121-27412-1 站 2015-11-14 25 | 65 | 1101010001 1 3 
9 978-7-5086-4166-9| 3 2016-01-15 10 | 65 |1101010001 . 2 
10 978-7-04-041372-4 1 2016-01-15 200 | 35 | 2201040001 3 
11 978-7-111-38074-0 1 2016-01-20 15 | 99 | 2201040002 1 1 
12 978-7-5049-6590-5 1 2016-01-22 3| 59 |2201040002 1 2 


























三 、 任务 分 析 


在 数据 表 中 输入 数据 需要 考虑 数据 表 间 的 关联 ,存在 关联 的 情况 下 ,首先 输入 父 表 数 
据 ,之 后 输入 子 表 数 据 。 输 入 数据 可 以 使 用 PHPMyAdmin 可 视 化 操作 工具 ,也 可 以 在 
MySQL 中 使 用 Insert 命令 实现 。 


四 、 预 备 知 识 


1. 增加 一 个 记录 


按 如 下 格式 执行 一 条 SQL 的 Insert … Values … 语 句 , 向 表 中 增加 一 个 数据 记录 。 
语句 格式 : 


Insert [Into] < 表 名 > 
Set < 字段 名 1>= (< 表达 式 1>)… [< 字段 名 n>=< 表 达 式 n>] 


2. 增加 多 个 记录 


按 如 下 格式 执行 一 条 SQL 的 Insert … Values … 语 句 , 向 表 中 增加 多 个 数据 记录 。 
语句 格式 : 


Insert [Into] < 表 名 > [ (< 字段 名 表 >)] 
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Values (< 表达 式 表 1>) … [, (< 表达 式 表 n>) ] 


3. 导入 数据 


数据 表 中 的 数据 内 容 较 多 时 (如 tsb .hyb 和 ygxsb) ,可 以 将 表 中 数据 按 其 他 格式 保 
存在 文件 中 ,之 后 使 用 PHPMyAdmin 的 导入 数据 功能 将 保存 的 表 记 录 文件 导入 到 数据 
表 中 。 在 PHPMyAdmin 中 支持 的 导入 数据 格式 有 CSV 文件 (*. csv)、CSV For MS 
Excel 文件 (* . xls) .PDF 文件 .SQL 文件 和 Microsoft Word 2000 等 。 

CSV(Comma-Separated Values ,逗号 分 隔 符 ) 用 逗号 分 隔 不 同 的 数据 项 ,CSV 文件 
以 纯 文本 形式 存储 表格 数据 ,可 以 使 用 记事 本 编辑 数据 记录 。 


五 、 技 能 点 


(1) 增加 记录 。 在 MySQL 中 用 命令 Insert 增加 记录 。 
(2) 导入 数据 。 在 PHPMyAdmin 中 使 用 导入 功能 将 保存 为 其 他 格式 的 数据 文件 添 
加 到 数据 表 中 。 


六 、 注 意 事 项 


(1) 数据 表 中 的 主键 能 够 避免 重复 输入 数据 记录 , 故 使 用 Insert 命令 插入 数据 记录 
时 ,相同 的 命令 不 能 重复 执行 。 

(2) 使 用 Insert 命令 增加 数据 ,需要 按照 命令 格式 输入 代码 ,因此 其 适合 于 少量 数据 
的 输入 ,输入 多 个 数据 记录 时 建议 使 用 PHPMyAdmin 等 可 视 化 操作 方式 以 减少 命令 的 
编写 时 间 。 


七 、 实 验 步骤 


1. 在 MySQL 中 输入 数据 

单 击 Windows“* 开 始 " 按 钮 ,在 “开始 "菜单 的 搜索 框 中 输入 cmd 后 按 Enter 键 ,系统 
进入 Windows 命令 行 ,输入 如 下 命令 并 按 Enter 键 : 

d: 

cd \xampp\mysql\bin 

mysql -uroot -p 

输入 root 用 户 的 登录 密码 后 进入 MySQL ,在 MySQL 提示 符 “mysql>” 后 输入 如 下 
命令 为 lbb 添加 数据 : 

Insert into lbb values ("B0", "哲学 理论 ")，("F0", "政治 学 ")，("F4"," 工 业经 济 ")， 

("F8", "金融 "), ("TM", "自动 化 技术 .计算 机 技术 ") ; 
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2. 在 PHPMyAdmin 中 SQL 命令 方式 输入 数据 


打开 XAMPP 面板 , 单 击 MySQL 动作 按钮 组 中 的 Admin 按钮 ,在 打开 页 面 的 登录 
框 中 输入 用 户 名 (如 root) 和 密码 ,登录 PHPMyAdmin 主页 。 单 击 PHPMyAdmin 主页 
导航 面板 中 的 wssd 数据 库 , 之 后 单 击 SQL 选项 卡 , 在 查询 编辑 窗口 中 输入 如 下 SQL 语 
句 后 单 击 “ 执 行 ” 按 钮 ,完成 数据 的 输入 


Insert into cbsb values ("04", "高 等 教育 出 版 社 "), ("111", "机械 工业 出 版 社 ")， 
("115"," 人 民 邮 电 出 版 社 "), ("121", "电子 工业 出 版 社 ")， 
("302", "清华 大 学 出 版 社 "), ("5049", "中 国 金融 出 版 社 ")，("5086", "中 信 出 版 社 ") ; 


3. 使 用 PHPMyAdmin 的 导入 功能 输入 数据 


在 记事 本 中 输入 表 2-8 中 的 内 容 , 只 输入 表 中 数据 ,不 需要 输入 表格 标题 行 信息 , 输 
人 格式 为 每 条 记录 以 按 Enter 键 结束 ,每 条 记录 中 不 同 的 数据 项 用 英文 逗号 分 隔 , 日 期 使 
用 /分 隔 ( 如 2014/12/10) ,时 间 格 式 数据 使 用 ”: ”分隔 (如 20:00:00) ,数据 格式 如 图 2- 
10 所 示 。 选 择 记事 本 “文件 ”菜单 一 “保存 ”项 ,输入 文件 名 tsbdata ,选择 编码 为 UTF-8， 
单 击 “ 保 存 ” 按 钮 ,保存 数据 文件 。 


[ar -= ex™)| 
| 文件 昌 ” 坊 缠 旧 ”格式 (QO) 查看 QW) 者 助 t， 


TP, 978-7-04-041372-4, 201 el 级 C 语 言 程序 设 
计 , 1, 1,2014/12/1, 04, 教育 部 考 试 中 心 编 ,35, 75 
TP, 978-7-04-044295-3, 2016 年 全 国 计 算 机 等 级 gi Basic 
千 程 序 设计 ,1, 1, 2015/12/1, 04， by 
TP,978-7-111-13289-0, 计算 机 专业 英语 
了 27 978-7-111-38074-0, C 程 序 设计 
即 














四 清 译 ,99, 85 
F4, 8 1 -5， ed 0 业 革 
命 ,1,7, 2015/2/1, 111, 乌 尔 里 希 . 琳 德 勒 3 李 现 民 译 , 45, 90 
F4; 978-7-115-40907-2, 破局 传统 行业 拥抱 互联 网 + 之 策略 与 法 
则 ;1, 1,2016/1/1, 115, 和 付 峥 嵘 著 , 45, 100 
F4' 378175115-41056-， 社 群 粉丝 经 济 玩 转 法 , 1, 1, 2016/1/10, 115, 郑 清 元 


著 , 4 
2721 ,Exce1 图 表 拒 绝 平 唐 〈 纪 念 , 1, 1,2015/12/1, 121, 陈 
民风 人 全 互联 网 运营 之 道 , 1, 1,2015/11/10, 121, 金正 


TP， 97827_302-22446-4， C 程 序 设 计 , 4， 2010/11/10, 302, 谭 浩 强 , 2 
TP, 978-7-302-25488-1, C++ 程 序 设计 (第 二 版 ) ， 1, i 2011/8/1， 302， ' 漳 洁 强 


著 ,48， 80 
TP, 978-7-302-35506-9, Visual BASIC 程 序 设计 《第 3 
版 ) ,3, 1,2011/12/1, 302, 评 浩 强 著 , 33. 5, 65 = 


cL J 


图 2-10 用 记事 本 输入 的 tsb 中 数据 
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在 PHPMyAdmin 中 单 击 导航 面板 中 的 wssd, 双 击 “ 结 构 ” 选 项 卡 中 的 tsb 表 名 , 选 
“导入 ?选项 卡 , 在 图 2-11 所 示 的 导入 界面 中 单 击 * 从 计算 机 中 上 传 : "选项 后 的 “ mw。 
钮 ,选择 保存 的 数据 文件 tsbdata. txt ,格式 选择 为 CSV, 单 击 “ 执 行 ”按钮 。 系 统 自 动 将 
tsbdata. txt 文件 中 的 数据 转化 为 若干 条 insert 语句 并 分 别 执行 这 些 语 句 , 本 例 中 ,执行 后 
系统 提示 “导入 成 功 ,执行 了 20 个 查询 。(tsbdata. txt)”, 单 击 “ 浏 览 ” 选 项 卡 可 以 查看 导 
人 到 tsb 中 的 具体 数据 信息 。 

用 同样 方式 在 记事 本 中 分 别 输入 并 保存 hyb( 表 2-9) 和 ygxsb( 表 2-10) 中 的 数据 ,之 
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文件 字符 集 utf-8 导入 数据 文件 
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phpMyAdmin 图 可 127001> @\ssdsBsb 网 
全 一世 本 日 @ 同 浏览 。 3% 结 # 过 “ 卫 插入 加 导出 更 多 
| (最 近 使 用 的 表 ) Ml 
要 导入 的 文件 : 
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-9 cdeol 匡 编 文件 名 必须 以 [ 燃 式 |[ 压 纺 方式 | 结尾 | 如 : .sqlzip 
Re 从 计算 机 中 上 传 : Dola 本 | 
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刘 加 mysql 文件 的 字符 集 : | utf8 加 


南 - performance_schema 
-3 phpmyadmin 
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导入 文件 格式 
2-11 PHPMyAdmin 导入 选项 卡 界 面 


后 使 用 PHPMyAdmin 的 导入 选项 卡 将 数据 通过 文本 文件 添加 到 对 应 的 数据 表 中 。 
4. 输入 违反 关联 规则 的 记录 
在 MySQL 中 执行 如 下 命令 ,查看 命令 的 执行 结果 


Insert into tsb (书号 , 印 次 , 书 名 , 译 著者 ,出 版 社 编码 ,类 别 编码 ) 
values ("978-7-5321- 3443- 4","2", "先秦 诸 子 百家争鸣 -中 天 "5321" "2nyy 


系统 给 出 的 出 错 信 息 如 下 : 

1452-Cannot add or update a child row: a foreign key constraint fails (wssd.tsb, 

CONSTRAINT 'FK' FOREIGN KEY (' 出 版 社 编码 ') REFERENCES 'cbsb' (' 出 版 社 编码 ') ON 

DELETE CASCADE ON UPDATE CASCADE). 

命令 中 要 添加 的 图 书 出 版 社 编码 5321 为 上 海 文艺 出 版 社 , 其 类 别 码 B2 对 应 中 图 分 
类 法 中 国 哲学 类 别 , 这 两 条 记录 信息 在 cbsb 和 1bb 中 均 不 存在 ,因此 不 能 添加 该 图 书信 
息 。 在 MySQL 中 执行 如 下 命令 添加 父 表 中 的 数据 记录 ,之 后 再 次 执行 以 上 命令 即 可 在 
tsb 中 添加 图 书信 息 。 


Insert into lbb values ("B2", "中 国 哲学 ") 
Insert into cbsb values ("5321", "上 海 文艺 出 版 社 ") 
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从 4 考题 


(1) 输入 数据 表 中 的 数据 都 有 哪些 方法 ? 在 数据 表 存 在 关联 的 情况 下 如 何 选择 数据 
表 输 入 数据 的 顺序 ? 

(2) 如 何 将 数据 表 复制 到 其 他 数据 库 中 ? 如 何 将 数据 表 中 的 数据 复制 到 其 他 数据 表 
中 ? 若 需要 复制 的 数据 在 两 个 不 同 的 数据 库 中 且 其 字段 名 不 完全 相同 ,此 时 如 何 完成 
操作 ? 


2.6 修改 售 书 数据 库 中 的 数据 


一 、 实 验 目的 
使 用 MySQL 及 PHPMyAdmin 数据 库 管理 工具 实现 数据 表 中 数据 的 修改 。 
二 、 实 验 任务 


(1) 在 MySQL 中 使 用 Update 命令 将 lbb 中 类 别 编码 Fo 对 应 的 类 别名 称 修改 为 
“政治 经 济 学 ”, 将 类 别 编码 TM 修改 为 TP, 查看 lbb 和 tsb 中 的 数据 变化 。 

(2) 使 用 PHPMyAdmin 查看 并 修改 tsb 中 的 数据 ,将 (计算 机 专业 英语 》 图 书 的 印 次 
日 期 修改 为 2004-9-15 ,定价 修改 为 25; 将 tsb 中 印 次 日 期 为 2015 年 的 图 书 的 印 次 日 期 修 
改 为 2016 年 ,定价 在 原 定价 的 基础 上 上 浮 10%% (只 取 整 数 结果 ) 。 


三 、 任 务 分 析 


修改 数据 表 中 的 数据 可 以 使 用 PHPMyAdmin 等 数据 库 管 理工 具 , 也 可 以 使 用 
MySQL 中 SQL 命令 Update 进行 操作 ,两 者 各 有 特点 。 


四 、 预 备 知识 


1. SQL 的 Update 语句 


执行 Update 语句 可 以 自动 修改 满足 条 件 记录 的 相关 字段 值 ,执行 此 语句 的 用 户 必 
须 具 有 表 “ 数 据 " 的 Update 权限 。 

语句 格式 : 

Update [Low_Priority] < 表 名 称 > Set < 字段 名 1>=< 表 达 式 1> 


[…,< 字 段 名 n>=< 表 达 式 n>] [ Where < 条 件 表 达 式 >] 
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2. PHPMyAdmin 的 可 视 化 操作 界面 


在 PHPMyAdmin 表 数 据 浏览 界面 (图 2-12) 中 , 单 击 所 选 记录 行 中 的 “编辑 "选项 ,在 
给 出 的 编辑 页 面 中 编辑 所 选 记录 , 单 击 “ 执 行 ” 按 钮 保存 修改 的 数据 。 




















在 新 窗口 中 创建 查询 
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图 2-12 PHPMyAdmin 中 的 数据 浏览 界面 


对 于 表 中 满足 相同 条 件 的 记录 进行 修改 操作 ,可 以 使 用 查询 编辑 器 按 条 件 查找 记录 ， 
之 后 再 对 满足 条 件 的 记录 进行 修改 操作 。 若 修改 的 内 容 满 足 相 同 的 条 件 , 则 可 以 在 查询 
编辑 器 中 使 用 Update 命令 直接 修改 “快速 编辑 ”选项 在 浏览 数据 的 上 方 给 出 简易 查询 
编辑 器 “编辑 选项 打开 新 的 页 面 给 出 完整 版 查询 编辑 器 ,用 于 SQL 语句 的 编辑 。 


五 、 技 能 点 
(1) 在 MySQL 中 修改 表 中 的 数据 。 在 MySQL 中 使 用 Update 命令 进行 修改 操作 。 


(2) 可 视 化 方式 修改 数据 。 在 PHPMyAdmin 数据 库 管理 工具 中 用 可 视 化 方式 修改 
数据 。 


六 、 注 意 事项 


(1) 修改 数据 表 中 主键 字段 中 的 内 容 时 需要 注意 ,修改 后 的 内 容 不 能 和 表 中 已 有 的 
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(4) 


(2) 当 数 据 表 间 存在 关联 时 , 若 关 联 表 的 更 新 约束 规则 为 Cascade, 则 在 修改 父 表 ( 如 
lbb) 中 关联 字段 值 ( 如 类 别 编码 ) 时 ,系统 自动 更 新 子 表 ( 如 tsb) 中 关联 记录 外 键 字段 的 值 
(如 类 别 编码 ); 若 关联 表 的 关联 类 型 为 No Action 或 Restrict, 则 对 子 表 中 存在 关联 记录 
的 父 表 记 录 ,不 能 修改 其 关联 字段 的 值 , 例 如 , 子 表 tsb 中 有 类 别 编码 (外 键 ) 为 TM 的 图 
书信 息 , 则 不 能 将 父 表 lbb 中 类 别 编码 (关联 字段 )TM 改 成 其 他 内 容 。 


七 、 实 验 步 又 


1. 在 MySQL 中 修改 数据 


单 击 Windows“ 开 始 ? 按 钮 ,在 “开始 ?菜单 搜索 框 中 输入 cmd 后 按 Enter 键 ,系统 进 
人 Windows 命令 行 ,在 命令 行 中 依次 输入 如 下 命令 并 按 Enter 键 ， 


di: 

cd \xampp\mysql\bin 

mysql -uroot -p 

输入 root 用 户 的 登录 密码 后 进入 MySQL。 在 MySQL 提示 符 “mysql 二 ”后 输入 如 
下 命令 修改 lbb 中 的 数据 : 

use wssd; 

update lbb set 类 别名 称 = "政治 经 济 学 " where 类 别 编码 ="F0"; 

update lbb set 类 别 编 码 ="TP" where 类 别 编码 ="TM"; 

输入 如 下 命令 查看 修改 后 的 数据 ,结果 可 见 ,修改 了 lbb 中 的 类 别 编码 ,其 在 tsb 中 
的 对 应 类 别 编码 字段 也 同步 进行 了 修改 。 

select * from lbb; 


select * from tsb where 类 别 编码 ="TP"; 


2. 在 PHPMyAdmin 中 修改 数据 


启动 XAMPP 控制 面板 , 单 击 MySQL 动作 按钮 组 中 的 Admin 按钮 ,在 打开 的 
PHPMyAdmin 页 面 登录 框 中 输入 用 户 名 (如 root) 和 密码 ,登录 PHPMyAdmin 主页 。 

(1) 单 击 PHPMyAdmin 主页 导航 面板 中 的 wssd, 单 击 “ 结 构 ” 选 项 卡 中 的 tsb 表 
名 ,在 tsb 的 数据 浏览 窗口 中 ,找到 图 书 ( 计 算 机 专业 英语 ), 选 择 数 据 行 中 的 “编辑 ” 选 
项 ,在 图 2-13 所 示 的 “插入 "选项 卡 中 找到 印 次 日 期 字段 ,在 “ 值 * 列 中 修改 印 次 日 期 为 
2004-09-15, 找 到 定价 字段 ,在 * 值 ? 列 中 将 其 值 修改 为 25 , 单 击 “执行 ?按钮 完成 数据 的 
修改 操作 。 

(2) 修改 tsb 中 印 次 日 期 为 2015 年 的 记录 信息 时 , 因 其 具有 相同 的 条 件 且 可 能 涉及 
多 册 图 书 , 故 选择 使 用 SQL 语句 进行 修改 。 选 择 tsb 数据 浏览 界面 工具 条 中 的 “编辑 ” 选 


基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


“ 值 " 列 





















































[ ee 
@9 i https flocalhost/phpmyadminfindex php?db=wssdartable D = S| Slocalhobt / 127.001 7 ws.. > J [下 > 
00 1 
公国 同日 目 洒 3 才 鬼 加 SQL 相安 关 二 A 有 SSH 辐 SA 六 报 作 本 冯 E 台 前 必 和 
他 字 息 大 型 El 空 全 
(这 使 用 的 表 [| 类 cc 加 | 口 [加 
| a cz 2 回 | 978-7-111-13289-0 
审 - 本 cdcol 
-eee vad) 回 计算 机 埋 北 英语 
此 -9 nformation_sc 
| 办 3 masq 版 交 。 char2) | 加 Oo 
店 -3 perommanee sc 一 al 
| B39 phpmyadmn 印 灾 char(2) 辐 
Ba rzp 一 | 
国名 rezp1 Pa 
志 i 印 次 B 期 date | 巴 肥 中 zosos's 局 | 
市- tk 
wd 出 用。 ca 全 加 上 0m 国 
着 泽 者 varchar(30) | 梧 吕 时 
定价 。 double(7.1) 回 口 隔 ] 
折扣 吝 int3) | 加 so 
af v| 
执行 ” 按 名 





2-13 PHPMyAdmin 中 可 视 化 修改 数据 界面 


项 ,在 给 出 页 面 的 SQL 选项 卡 中 输入 如 下 SQL 语句 后 , 单 击 * 执 行 " 按 钮 。 


update tsb set 印 次 日 期 =date_add ( 印 次 日 期 , interval 1 year)， 
定价 =round (定价 * 1.1)where year ( 印 次 日 期 )=2015; 

其 中 date_add() 函 数 完成 日 期 的 加 法 计算 ,其 在 当前 印 次 日 期 ( 即 条 件 中 的 2015 
年 ) 的 基础 上 增加 1 年 ;Round() 函 数 完 成 数值 的 四 舍 五 入 运算 ,Round( 定 价 * 1. 1) 相 
当 于 Round( 定 价 * 1.1,0), 即 定价 采用 整数 值 ;Year() 函 数 用 于 提取 给 定 日 期 中 的 
年 份 。 

语句 正确 执行 后 ,系统 提示 “影响 了 $6 行 数据 ”, 在 数据 浏览 窗口 中 可 以 查看 数据 的 变 
化 情况 。 


八 、 思 考题 


(1) 可 以 使 用 哪些 方法 修改 数据 表 中 的 数据 ?可 以 使 用 SQL 的 Replace 命令 完成 数 
据 的 修改 操作 吗 ? 

(2) 修改 数据 过 程 中 可 能 出 现 修改 错误 ,如 何 避 免 修改 错误 对 数据 表 中 数据 的 
损害 ? 
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2.7 删除 售 书 数据 库 中 的 数据 
一 、 实 验 目 的 
使 用 MySQL 及 PHPMyAdmin 数据 库 管理 工具 实现 数据 表 中 数据 的 删除 。 
二 、 实 验 任务 


(1) 删除 hyb 中 购买 记录 为 0 的 会 员 信息 。 
(2) 删除 tsb 中 购买 记录 为 0 的 全 部 图 书信 息 。 
(3) 删除 ygxsb 中 未 付款 且 目 前 状态 为 未 发 货 的 全 部 订单 。 


三 、 任 务 分 析 


要 删除 表 中 的 数据 ,可 以 在 MySQL 中 使 用 SQL 的 Delete 命令 实现 ,也 可 以 通过 
PHPMyAdmin 等 管理 工具 实现 。 若 确认 表 中 数据 及 表 结 构 均 不 再 需要 ,可 以 直接 删除 


四 、 预 备 知识 


1. 用 SQL 语句 删除 数据 

通过 Delete 语句 ,可 以 删除 满足 条 件 的 记录 ,也 可 以 无 条 件 地 删除 表 中 的 全 部 记录 ， 
使 之 成 为 空 表 。 执 行 删除 记录 语句 的 用 户 必须 具有 表 “ 数 据 " 的 Delete 权限 。 

语句 格式 : 


Delete [Low_Priority] [Quick] From < 表 名 > [Where < 条 件 表达 式 >] 


2. 在 PHPMyAdmin 中 删除 数据 


在 PHPMyAdmin 中 单 击 打开 数据 库 ( 如 wssd) ,在 数据 库 窗 格 中 单 击 表 名 (如 cbsb) 
或 表 名 后 的 “浏览 ”按钮 ,在 图 2-14 所 示 的 数据 管理 界面 中 完成 数据 的 删除 操作 。 要 删除 
某 个 记录 , 单 击 该 记录 行 中 的 “删除 ?选项 即 可 ;要 删除 多 个 记录 , 先 选择 需要 删除 的 记录 ， 
再 单 击 表 浏览 数据 下 方 的 “删除 ”按钮 ;要 按 条 件 删 除数 据 可 以 使 用 SQL 创建 查询 ,在 查 
询 中 使 用 Delete 命令 ,执行 查询 删除 数据 。 
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新 建 查询 
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五 、 技 能 点 


(1) 可 视 化 方式 删除 数据 。 在 PHPMyAdmin 数据 浏览 界面 删除 数据 ;执行 查询 设 
计 器 生成 的 查询 语句 实现 数据 的 删除 操作 。 

(2) 命令 方式 删除 数据 。 在 MySQL 中 使 用 命令 Delete 实现 数据 的 删除 ,在 
PHPMyAdmin 中 新 建 查询 ,查询 中 使 用 Delete 命令 删除 数据 。 


六 、 注 意 事 项 


(1) 数据 表 中 删除 的 数据 通常 无 法 恢复 ,所 以 进行 删除 操作 一 定 要 确保 欲 删除 的 数 
据 不 再 需要 ,建议 操作 前 备份 数据 库 或 备份 删除 操作 涉及 的 数据 表 。 

(2) 在 数据 表 间 存在 关联 的 情况 下 , 若 删除 约束 规则 为 Cascade, 则 删除 父 表 中 的 数 
据 会 自动 删除 其 关联 子 表 中 相同 关键 字 的 全 部 数据 ; 若 删除 约束 规则 为 Restrict 或 
NoAction, 则 在 子 表 存 在 相同 关键 字 记录 时 ,系统 拒绝 删除 父 表 中 的 数据 。 


七 、 实 验 步 又 


1. 在 MySQL 中 删除 hyb 中 的 数据 
单 击 Windows“ 开 始 ” 按 钮 ,在 “开始 ”菜单 的 搜索 框 中 输入 cmd 后 按 Enter 键 ,系统 
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地 


进入 Windows 命令 行 ,在 命令 行 中 依次 输入 如 下 命令 并 按 Enter 键 。 


ds 

cd \xampp\mysql\bin 

mysql -uroot -p 

输入 root 用 户 的 登录 密码 后 进入 MySQL。 在 MySQL 提示 符 “mysql>” 后 输入 如 
下 命令 ,删除 hyb 中 购书 金额 为 零 的 会 员 信 息 。 

use wssd; 

select * from hyb where 累计 购书 金额 =0; ”/* 查看 hyb 中 累计 购书 金额 为 0 的 记录 * / 

delete from hyb where 累计 购书 金额 =0; /* 删除 数据 * / 

select * from hyb where 累计 购书 金额 =0; ”/* 再 次 查看 hyb 中 累计 购书 金额 为 0 的 记录 */ 


命令 中 删除 前 浏览 了 累计 购书 金额 为 0 的 会 员 记录 ,执行 删除 操作 后 再 次 浏览 了 累 
计 购书 金额 为 0 的 会 员 记 录 。 
操作 完成 后 在 MySQL 中 执行 quit 或 exit 命令 关闭 MySQL。 


quit; 


2. 在 PHPMyAdmin 中 使 用 SQL 语句 删除 tsb 中 的 数据 


启动 XAMPP 控制 面板 , 单 击 MySQL 动作 按钮 组 中 的 Admin 按钮 ,在 打开 的 
PHPMyAdmin 页 面 登录 框 中 输入 用 户 名 (如 root) 和 密码 ,登录 PHPMyAdmin 主页 。 

(1) 单 击 PHPMyAdmin 主页 导航 面板 中 的 wssd 数据 库 ,选择 SQL 选项 卡 ,在 查询 
编辑 器 中 输入 如 下 语句 ,用 来 查询 tsb 中 没有 购买 记录 的 图 书信 息 , 单 击 “ 执 行 ” 按 钮 执行 


语句 。 

select 书号 , 书 名 from tsb where 书号 not in (select 书号 from ygxsb); 

(2) 选择 SQL 选项 卡 ,在 查询 设计 器 中 输入 如 下 语句 ,删除 tsb 中 未 有 销售 记录 的 图 
书 数据 , 单 击 “ 执 行 ”按钮 执行 语句 。 

delete from tsb where 书号 not in (select 书号 from ygxsb); 

(3) 单 击 “浏览 "选项 卡 ,查看 tsb 中 的 数据 变化 。 

3. 在 PHPMyAdmin 中 借助 “查询 ”选项 卡 删除 ygxsb 中 的 数据 


在 PHPMyAdmin 主页 面 中 单 击 导 航 面板 中 的 wssd 数据 库 , 选 择 “ 查 询 ” 选 项 卡 , 在 
图 2-15 所 示 的 查询 选项 卡 界面 中 使 用 可 视 化 方式 设计 查询 语句 。 界 面 中 默认 3 列 操 作 
项 ,通过 界面 左下 角 的 “添加 /删除 字段 ”项 可 以 增加 或 减少 操作 列 数 。 选 择 字段 后 选中 其 
“显示 ? 行 中 的 复 选 按钮 ,即将 该 字段 作为 查询 的 结果 列 内容 。“ 条 件 " 为 查询 的 筛选 条 件 ， 
多 个 条 件 之 间 的 逻辑 关系 通过 修改 行 中 的 “与 “或 "实现 连接 。 

完成 查询 选项 的 设计 后 单 击 “ 更 新 查询 ”按钮 ,在 查询 设计 器 下 方 生 成 对 应 的 SQL 语 
句 , 与 图 2-15 对 应 的 SQL 语句 如 下 : 
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SELECT 'ygxsb'.* FROM 'Ygxsb' 
WHERE (('ygxsb' .' 付 款 标记 ' = '0') AND ('ygxsb'.' 目 前 状态 ' ="'0')) 


单 击 “提交 查询 ”按钮 可 以 执行 查询 功能 ,查看 查询 结果 确定 设置 的 查询 条 件 无 误 后 ， 
复制 生成 的 SQL 语句 到 SQL 选项 卡 中 ,将 语句 中 的 “SELECT 'ygxsb' * ”修改 为 
“Delete" 后 , 单 击 * 执 行 ?按钮 ,在 给 出 的 确认 对 话 框 中 单 击 “确定 ”按钮 即 可 完成 数据 的 删 
除 操作 。 


显示 列 条 件 条 件 列 











条 件 : =0 Do 

插入 : 口 与 :O 

删除 : 口 或 : 回 

修改 : 或 :DO 与 :®@ 或 :D 与 :@ 与 :图 
插入 口 删除 口 插入 口 划 除 口 插入 口 划 除 口 


添加 /出 除 标准 行 | 0 |] 添加 删除 字段 ; 0 v] | 更 新 查询 











| 
增加 /减少 界面 列 数 ， 默 认 3 列 更 新 查询 ， 生 成 SQL 语句 
图 2-15 PHPMyAdmin 中 的 “查询 ”选项 卡 
八 、 思 考题 
(1) 删除 表 中 数据 可 以 使 用 MySQL 和 PHPMyAdmin 等 多 种 工具 ,这 几 种 工具 各 有 


哪些 特点 ? 
(2) 在 误 删 除数 据 表 中 的 数据 后 ,有 哪些 方法 能 够 减少 数据 的 损失 ? 
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利 3 元 


SQL 数据 查询 及 统计 分 析 


数据 查询 及 统计 分 析 是 实际 业务 处 理 中 的 一 项 重要 内 容 , 诸 如 数据 检索 .排序 .分 类 
统计 和 数据 合并 等 都 属于 数据 查询 及 统计 分 析 的 业务 范畴 。 

简单 的 数据 检索 问题 可 以 充分 利用 SQL 的 基本 Select 语句 来 解决 ;常规 的 数据 排序 
和 分 类 统计 一 般 由 Select 语句 中 的 排序 (Order By) 和 分 组 (Group By) 短 语 来 实施 ;比较 
复杂 的 业务 处 理 任 务 需要 借助 SQL 的 嵌 套 、 合 并 或 视图 进行 综合 设计 。 

本 单元 以 网 上 售 书 为 实例 ,实际 演练 SQL 语句 的 编写 方法 和 执行 过 程 ,使 读者 通过 
案例 理解 和 掌握 SQL 语句 的 功能 .用 法 和 设计 技巧 , 练 就 数据 检索 和 统计 分 析 的 技能 , 提 
升 用 计算 机 技术 解决 较 复杂 问题 的 能 力 。 


3.1 Select 语句 的 编辑 和 运行 环境 检测 


一 、 实 验 目的 


充分 利用 PHPMyAdmin 可 视 化 数据 库 管 理工 具 , 学 习 生 成 .编辑 和 运行 SQL 语句 
的 过 程 和 方法 ,掌握 设计 和 运行 MySQL 语句 的 一 种 操作 环境 和 实际 应 用 技能 。 
二 、 实 验 任务 


(1) 查看 图 书 的 书号 、 书 名 和 定价 。 
(2) 浏览 未 付款 的 订单 信息 。 


三 、 任 务 分 析 
两 个 实验 任务 的 数据 源 都 来 源 于 一 个 数据 表 , 并 且 输 出 各 列 的 数据 都 可 以 由 数据 表 


中 的 字段 直接 提取 ,因此 ,比较 简捷 的 操作 方法 是 通过 PHPMyAdmin 的 SQL 语句 编辑 
窗口 生成 Select 语句 ,在 此 基础 上 再 进行 少量 修改 便 可 完成 任务 的 要 求 。 


四 、 预 备 知 识 


(1) 基本 Select 语句 。Select 过 表达 式 表 From 二 数据 源 名 之 Where 一 条 件 二 。 

(2) SQL 语句 的 编辑 与 执行 环境 。 在 PHPMyAdmin 的 主页 ,选择 当前 数据 库 名 (如 
wssd) ,选择 数据 表 名 (如 tsb) ,选择 代码 编辑 工具 “编辑 ”, 进 入 SQL 语句 的 编辑 窗口 ,可 
以 生成 简单 的 Select 语句 ,如 图 3-1 所 示 。 
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图 3-1 SQL 语句 编辑 窗口 


在 此 基础 上 ,可 以 进一步 编辑 .完善 或 执行 Select 语句 。 
五 、 技 能 点 


(1) 生成 Select 语句 。 恰 当地 运用 工具 ,生成 接近 完成 任务 的 Select 语句 。 

(2) 编辑 Select 语句 。 在 系统 生成 的 Select 语句 基础 上 ,删除 .增加 和 修改 相关 内 
容 ,使 之 成 为 完成 任务 的 Select 语句 。 

(3) 调试 Select 语句 。 运 行 Select 语句 出 错 或 结果 不 正确 时 ,能 够 发 现 和 纠正 错误 。 

(4) 执行 Select 语句 。 检 验 Select 语句 的 运行 结果 是 否 满足 任务 的 要 求 。 


六 、 注 意 事 项 


(1) 在 系统 生成 的 Select 语句 中 ,数据 库 数据 表 和 字段 名 称 均 用 左 单 引号 (“~” 
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键 的 下 档 符 号 ) 括 起 来 ,不 能 用 右 单 引号 "或 双 引 号 ”代替 该 符号 。 

(2) Select 语句 中 出 现 的 数据 库 、 数 据 表 或 字段 名 以 外 的 符号 ,一 律 以 半角 方式 输 
入 ,如 Select、From、 各 种 引号 、 逗 号 、 圆 点 、 括 号 和 分 号 等 。 英 文字 母 不 区 分 大 小 写 。 

(3) 一 条 语句 可 以 分 多 行 编写 ,但 不 能 在 一 个 完整 项 (如 语句 名 、 短 语 名 、 数 据 库 名 、 
数据 源 名 \ 字 有 段 名 、 函 数 调用 或 数据 等 ) 的 中 间 分 行 。 


七 、 实 验 步 又 
1. 查看 图 书 相关 信息 


(1) 进入 SQL 语句 编辑 窗口 。 在 PHPMyAdmin 的 主页 ,选择 数据 库 名 为 wssd, 数 
据 表 名 为 tsb, 代 码 编辑 工具 为 “编辑 ”。 

(2) 生成 SQL 的 Select 语句 。 单 击 SQL 语句 编辑 窗口 中 的 SELECT 按钮 ,生成 的 
语句 如 图 3-1 所 示 。 

(3) 编辑 Select 语句 。 在 SQL 语句 编辑 框 中 ,保留 SELECT 之 后 的 书号 、 书 名 和 定 
价 ,删除 其 他 多 余 的 信息 。 修 改 后 的 语句 如 下 : 


SELECT 书号 , 书 名 ,定价 FROM `tsb、 


(4) 执行 Select 语句 。 单 击 SQL 语句 编辑 窗口 中 的 “执行 "按钮 ,在 Select 语句 的 执 
行 结果 窗口 (如 图 3-2 所 示 ) 中 可 以 观察 到 运行 结果 。 
执行 的 SQL 语句 。 设置 显示 行 数 返回 SQL 语句 编辑 窗口 的 工具 





SELECT 4 书 名 ,定价 | 
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#6} 书 名 定价 
978.7.04.041372-4 | 2015 年 版 全 国 计 算 机 等 级 考试 二 级 教程 C 滞 言 程序 设计 350 
9787.04.044295.3 2016 年 全 国 计 和 草 机 等 级 考试 二 级 教程 Visual Basic 语 言 程序 设计 | 50.0 | 
978-7-111-13269.0 | 计算 机 考 业 英 i 290 
9787-111-390740 | 0 程序 设计 E22 
978-7-111-47161-5 | 工业 4.0 即 将 来 尾 的 第 四 次 工业 革命 450 
9787-11540907.2 | 破局 网 + 之 策略 与 法 则 1450| 








排序 索引 选择 框 执行 结果 的 数据 行 
图 3-2 Select 语句 的 执行 结果 窗口 


(5) 如 果 执 行 Select 语句 出 错 或 者 运行 结果 不 符合 要 求 , 则 需要 单 击 Windows 任务 
栏 中 的 SQL 语句 编辑 窗口 图 标 , 回 到 编辑 窗口 继续 编辑 、 运 行 Select 语句 。 
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2. 浏览 未 付款 的 订单 


(1) 在 PHPMyAdmin 的 主页 ,选择 数据 库 名 为 wssd, 数 据 表 名 为 ygxsb, 代码 编 辑 
工具 为 “编辑 ”。 

(2) 单 击 SQL 语句 编辑 窗口 中 的 “SELECT * ”按钮 ,生成 SELECT * FROM 
ygxsb WHERE 1 语句 。 

(3) 在 SQL 语句 编辑 框 中 , 选 定 WHERE 1 中 的 1. 双击 字段 列表 框 中 的 “付款 标 
记 ”, 在 生成 的 “付款 标记 ?字段 前 插入 NOT 运算 符号 ,最 后 的 语句 如 下 : 

SELECT * 


FROM “`yYgxsb ~ 
WHERE NOT “付款 标记 


(4) 单 击 SQL 语句 编辑 窗口 中 的 “执行 ”按钮 ,查看 执行 效果 。 


八 、 思 考题 


(1) 在 MySQL 命令 行 和 PHPMyAdmin 的 SQL 语句 编辑 窗口 都 可 以 编辑 和 执行 
Select 语句 ,这 两 种 方法 各 自 的 特点 是 什么 ? 

(2) 进入 PHPMyAdmin 的 主页 之 前 ,要 进行 哪些 操作 ? 执行 数据 查询 的 用 户 应 该 
具有 哪些 权限 ? 当 不 具备 数据 查询 权限 的 用 户 执行 Select 语句 时 ,系统 将 会 如 何 反应 ? 

(3) 表达 式 “NOT 付款 标记 ”与 “付款 标记 Is False” 的 功能 是 否 等 效 ? 与 之 等 效 的 表 
达 式 有 哪些 ? 


3.2 查询 语句 的 表达 式 设 计 


一 、 实 验 目 的 

学 习 各 类 表达 式 的 设计 方法 和 手段 ,掌握 表达 式 的 用 途 和 基本 要 素 ,特别 是 各 类 运算 
符 ,谓词 及 其 相关 函数 的 基本 作用 和 功能 ,学 会 设计 能 解决 实际 问题 的 各 类 表达 式 。 
二 、 实 验 任务 


(1) 检索 定价 为 30 一 50 元 ,有 关 互 联网 方面 的 图 书信 息 。 

(2) 检索 出 版 社 名 称 中 含有 “大 学 ”或 “教育 ”两 个 字 的 出 版 社 信 息 。 

(3) 检索 最 近 30 天 图 书 的 订单 信息 ,输出 内 容 包 括 预 购 单 号 、 书 号、 预购 日 期 \ 册 数 、 
付款 标记 和 目前 状态 。 付 款 标记 (逻辑 型 ) 和 目前 状态 (字符 编码 ) 都 转换 成 汉字 名 称 。 
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@) 


芋 * 任务 分 析 


前 两 个 任务 需要 设计 数据 检索 条 件 , 主 要 设计 Select 语句 的 Where 一 条 件 表 达 式 二 。 
条 件 表达 式 由 关系 运算 .逻辑 运算 .谓词 运算 及 其 相关 函数 组 成 ,运算 结果 为 逮 辑 真 ( 非 
0) 或 假 (0)。 第 一 个 任务 用 谓词 LIKE 和 BETWEEN 即 可 实现 ;第 二 个 任务 用 谓词 
RLIKE 和 LIKE 均 可 以 完成 ,但 用 RLIKE 效果 更 佳 ; 最 后 一 个 任务 需要 借用 IF 和 ELT 
函数 设计 Select 二 表达 式 之 (计算 列 ) ,用 DATEDIFF 函数 和 关系 运算 设计 数据 检索 
条 件 。 


四 、 预 备 知识 


(1) 谓词 区 间 判 断 BETWEEN。X BETWEEN Y And Z, 等 效 于 X>>=Y AND X 一 
二 

(2) 谓词 匹配 运算 LIKE。 志 字符 串 表 达 式 1 LIKE 二 字符 串 表 达 式 2 二 ,字符 串 
表达 式 2 中 可 含 匹 配 符 号 “%%? 或 ””, 表 示 其 位 置 有 任意 多 个 或 一 个 符号 。 

(3) 谓词 选择 匹配 运算 RLIKE。 去 字符 串 表 达 式 之 RLIKE 一 子 串 1 二 [| 过 子 串 2 二 … 
| 二子 串 n>] ,一 般 用 于 分 析 字 符 串 表 达 式 的 值 中 是 否 含有 子 串 之 一 。 

(4) IF(X,Y,2Z) 函 数 。 如 果 X 值 为 真 ( 非 0) , 则 函数 值 为 Y, 否 则 ,函数 值 为 Z。 

(5) ELTCN,SL,S ,So。])。 数 据 编码 转换 成 名 称 的 函数 。 

(6) DATEDIFF(D1,D2) 函 数 。 计 算 D1 与 D2 两 个 日 期 之 间 的 天 数 。 如 果 第 一 个 
参数 为 系统 日 期 函数 CurDate() , 则 可 以 计算 D2 到 调用 该 函数 当天 的 天 数 。 


五 、 技 能 点 


(1) 条 件 表 达 式 设计 。 恰 当地 运用 各 类 运算 符 和 函数 设计 Where 二 条 件 表达 式 二 。 
(2) 计算 列 设计 。 正 确 设计 Select 二 表达 式 二 ,同时 能 为 计算 列 命 名 列 名 称 及 标题 。 


六 、 注 意 事项 


(1) 在 调用 函数 时 ,参数 要 写 在 小 括号 内 ,即使 没有 参数 ,小 括号 也 不 能 省 略 。 

(2) 在 LIKE 和 RLIKE 运算 符 右 侧 的 字符 串 中 ,所 包含 的 *“%”“_" 或 | "不 是 要 检索 
的 符号 ,它们 的 含义 是 匹配 符号 或 分 隔 符号 。 

(3) 调用 ELT 函数 时 ,第 一 个 参数 是 数值 或 数字 串 型 表达 式 ; 其 他 参数 为 对 应 编码 
顺序 (从 1 开始 ) 名 称 的 字符 串 型 表达 式 。 

(4) 调用 DATEDIFF 函数 时 ,两 个 参数 均 为 日 期 型 表达 式 ,日 期 型 常数 要 用 单 引 号 
或 双 引 号 引起 来 。 

(5) Where 所 条 件 表达 式 二 中 可 以 含 字段 名 .常数 和 普通 函数 ,但 不 能 使 用 As 定义 
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的 列 名 和 有 关 数 据 统计 函数 (如 AVG、MAX 和 Sum 等 )。 
(6) 用 一 表达 式 > As 二 列 名 称 > 为 计算 列 命名 列 名 时 ,As 左右 至 少 各 一 个 空格 ,省 
略 As 时 ,表达 式 与 列 名 称 之 间 至 少 有 一 个 空格 。 


七 、 设计 步 又 
1. 检索 定价 为 30~50 元 , 书 名 中 含 互 联网 的 图 书 


(1) 单 击 数据 库 名 wssd ,选择 数据 表 名 tsb 和 代码 编辑 工具 “编辑 ”。 
(2) 在 编辑 框 中 系统 生成 的 语句 最 后 再 加 短语 。WHERE 定价 BETWEEN 30 
AND 50 AND 书 名 LIKE"% 互 联网 %", 最 后 的 语句 如 下 : 
SELECT * 
FROM `tsb、 
WHERE 定价 
BETWEEN 30 
AND 50 
AND 书 名 LIKE "s 互 联网 %" 


(3) 单 击 SQL 语句 编辑 窗口 中 的 “执行 ”按钮 。 
2. 检索 出 版 社 信息 
与 上 述 设计 和 执行 过 程 相似 ,满足 任务 要 求 的 语句 如 下 : 


SELECT * FROM ‘cbsb° 
WHERE 出 版 社 名 称 RLIKE "大 学 | 教育 " 


3. 检索 最 近 30 天 的 订单 


(1) 单 击 SQL 语句 编辑 窗口 中 的 “清除 ”按钮 。 
(2) 在 SQL 语句 编辑 框 中 输入 如 下 语句 : 


SELECT 预购 单 号 ,书号 ,预购 日 期 , 册 数 ， 


IF (付款 标记 , "已 付 ", "未 付 ") as 付款 ， /* 逻辑 型 数据 转 汉 字 名 称 * / 
ELT (目前 状态 , " 没 发 送 ", "取消 ", "在 途 ", "签收 ", "退货 ") as 状态 /* 编码 转 汉字 * / 
FROM ygxsb 


WHERE DATEDIFF ( CURDATE ( ) ,预购 日 期 )<=30 


(3) 单 击 SQL 语句 编辑 窗口 中 的 “执行 ”按钮 ,查看 执行 效果 。 


八 、 思 考题 


(1) 谓词 BETWEEN 能 否 对 其 他 数据 类 型 (如 字符 串 .日 期 等 ) 的 数据 进行 运算 ? 
(2) 谓词 RLIKE 和 LIKE 从 功能 方面 有 什么 区 别 ? 在 上 述 Select 语句 中 ,如 果 将 
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RLIKE 换 成 LIKE ,或 者 将 LIKE 换 成 RLIKE, 则 应 该 如 何 设计 相关 的 条 件 表达 式 , 同 样 
确保 完成 任务 ? 

(3) 用 IF 和 ELT 函数 都 可 以 将 数据 编码 转换 成 名 称 , 在 什么 情况 下 用 ELT 函数 更 
合适 ? 如 果 将 性 别 码 (1 表示 男 ,2 表示 女 ) 转 换 成 汉字 ,如 何 调用 这 两 个 函数 ? 


3.3 多 个 数据 源 的 查询 设计 


一 、 实 验 目的 


学 习 和 巩固 多 个 数据 源 (数据 表 或 视图 ) 的 连接 方法 ,掌握 数据 源 之 间 的 常用 连接 类 
型 .功能 以 及 必要 条 件 ,学 会 从 多 个 数据 源 中 同时 提取 所 需要 的 数据 ,深入 理解 数据 源 之 
间 关 联 的 作用 和 必要 性 。 


二 、 实验 任 务 


(1) 检索 本 年 度 印刷 的 、 书 名 中 包含 “计算 机 ”和 "程序 设计 ”的 图 书信 息 , 输 出 出 版 社 
名 称 、 书 号 、 书 名 、 印 次 日 期 .定价 和 折扣 率 。 

(2) 输出 还 未 付款 的 预购 图 书信 息 ,内 容 包括 会 员 的 姓名 、 移 动 电话 .Email 账号 、 书 
名 、\ 预 购 日 期 , 册 数 、 售 价 和 应 付 金额 。 

(3) 输出 每 个 出 版 社 发 行 的 图 书 类 别 ,内容 包括 出 版 社 名 称 和 类 别名 称 。 

(4) 输出 目前 还 没有 人 预购 的 图 书信 息 ,内 容 包 括 书 号 和 书 名 。 


三 、 任务 分 析 


第 一 个 任务 要 求 输出 的 出 版 社 名 称 来 源 于 出 版 社 表 (cbsb), 书 号 和 书 名 等 列 以 及 查 
询 条 件 中 所 用 到 的 印 次 日 期 和 书 名 字段 都 来 源 于 图 书 表 (tsb), 因 此 ,需要 同时 连接 这 两 
个 表 。 同 样 理 由 ,第 二 个 任务 需要 会 员 表 (hyb) 、 预 购销 售 表 (ygxsb) 和 图 书 表 (tsb) 三 个 
表 进 行 同时 连接 。 

从 输出 结果 要 求 来 看 ,第 三 个 任务 仅 需要 出 版 社 表 (cbsb) 和 类 别 表 (lbb) ,但 这 两 个 
表 之 间 只 能 通过 图 书 表 (tsb) 间 接地 建立 关联 ,因此 ,也 需要 三 个 表 进 行 连接 。 另 外 ,由 于 
同一 个 出 版 社 可 能 出 版 多 本 同类 别 的 图 书 , 所 以 还 要 加 Distinct 短语 ,以 便 限制 输出 重复 
的 数据 行 。 

第 四 个 任务 依据 是 否 有 人 预购 来 决定 输出 图 书信 息 ,实质 要 输出 图 书 表 (tsb) 中 与 预 
购销 售 表 (ygxsb) 无 关联 的 记录 ,因此 ,连接 类 型 应 该 选择 左 连接 或 右 连 接 ,并 与 IsNull 
函数 结合 操作 。 


T 
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四 、 预 备 知 识 


(1) Where 一 连接 条 件 之 。 通 常 是 两 个 数据 源 关 联 关键 字 的 等 值 表达 式 。 

(2) 二 数据 源 名 1 二 [二 连接 类 型 二 一 数据 源 名 2 之 LOn 雪 连 接 条 件 之 ]。 连 接 类 型 
常用 Join( 内 连接 )、Left Join( 左 连接 ) 、Right Join( 右 连接 ) 和 Natural Join( 自 然 连 接 , 不 
用 On 二 连接 条 件 之 ,实质 是 两 个 数据 源 中 同名 字段 的 等 值 连接 )。 连 接 条 件 通 常 都 是 关 
联 关键 字 的 等 值 表达 式 。 


五 、 技 能 点 


(1) 连接 类 型 选择 。 选 择 合适 的 连接 方式 和 类 型 可 以 简化 Select 语句 ,提高 数据 查 
询 速度 。 

(2) 连接 条 件 设 计 。 为 数据 源 之 间 的 连接 设置 表达 式 , 表 达 式 的 值 是 决定 数据 源 中 
记录 连接 成 功 与 否 的 条 件 。 


六 、 注 意 事 项 


(1) 两 个 或 更 多 数据 源 中 出 现 的 字段 名 ,其 前 必须 加 “数据 源 名 .”, 但 连接 类 型 为 
Natural Join 时 ,不 受 此 限制 。 

(2) On 二 连接 条 件 二 必须 与 某 个 连接 类 型 (Join、Left Join 或 Right Join 等 ) 结 合 使 
用 ,不 能 单独 存在 。 

(3) Select 语句 中 各 个 数据 源 之 间 都 要 直接 或 间接 地 进行 关联 ,否则 ,将 产生 不 可 预 
测 的 查询 结果 。 


七 、 设 计 步 又 


(1) 检索 本 年 度 印刷 的 图 书信 息 ,语句 如 下 : 


SELECT 出 版 社 名 称 ,，tsb. 书 号 , 书 名 , 印 次 日 期 , 定价 , 折扣 率 
FROM cbsb, tsb 
WHERE cbsb .出 版 社 编码 =tsb. 出 版 社 编码 /* 表 等 值 连接 条 件 * / 
AND YEAR ( 印 次 日 期 )=YEAR (CurDate()) /+ 当前 年 份 * / 
AND 书 名 LIKE "# 计 算 机 gs" 
AND 书 名 LIKE "s 程 序 设计 s" 


(2) 输出 还 没 付款 的 预购 图 书信 息 的 语句 如 下 : 


SELECT 姓名 ， 移 动 电话 ，EMRAIL 账号 , 书 名 ,预购 日 期 , 册 数 ,和 售 价 ， 
售 价 * 册 数 应 付 金额 /* 省 略 As, "应 付 金额 "前 至 少 用 1 个 空格 * / 
FROM hyb 
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JOIN ygxsb /=* 内 连接 ,省 略 Inner* / 

JOIN tsb ON hyb .会 员 账 号 =ygxsb .会 员 账 号 

AND ygxsb. 书 号 =tsb .书号 /* 用 AND 运 算 多 个 数据 源 的 连接 条 件 * / 
WHERE ! 付 款 标记 


(3) 输出 每 个 出 版 社 发 行 的 图 书 类 别 的 语句 如 下 : 
SELECT DISTINCT 出 版 社 名 称 ， 类 别名 称 


FROM cbsb 
NATURAL JOIN tsb /* 自然 连接 ,实质 按 出 版 社 编码 等 值 连接 * / 
NATURAL JOIN 1bb /* 自然 连接 ,实质 按 类 别 编码 等 值 连接 * / 


(4) 输出 目前 还 没有 人 预购 的 图 书信 息 的 语句 如 下 : 


SELECT tsb .书号 ， 书 名 


FROM tsb 

LEFT JOIN ygxsb ON tsb .书号 =ygxsb .书号 /* 左 连接 及 条 件 * / 

WHERE ISNULL (预购 单 号 ) /* ygxsb 中 无 匹配 记录 时 ,预购 单 号 为 NullLx / 
八 、 思考 题 


(1) 任务 1~4 的 设计 语句 中 ,数据 源 之 间 的 连接 类 型 及 条 件 是 否 都 可 以 用 自然 连接 
来 实现 ?如 何 修 改 Select 语句 才能 用 自然 连接 ? 自然 连接 有 了 哪些 优点 ?要 使 用 自然 连 
接 , 对 定义 表 结 构 有 哪些 要 求 ? 

(2) 如 何 修改 第 4 个 任务 的 Select 语句 ,使 之 用 右 连接 完成 任务 ? 

(3) 在 本 实验 的 Select 语句 中 ,有 几 处 出 现 “tsb. 书号 ”, 哪 条 语句 中 可 以 省 略 “tsb. ”? 
为 什么 其 他 位 置 不 能 省 略 “tsb. ”? 

(4) 将 第 1 个 任务 的 Select 语句 中 的 “ 书 名 LIKE"% 计 算 机 %"AND 书 名 LIKE 
"% 程 序 设计 %"" 改 为 “ 书 名 RLIKE "计算 机 | 程序 设计 "”, 功 能 是 否 相同 ? 为什么? 


3.4 数据 统计 分 析 设 计 


一 、 实 验 目的 

学 习 数 据 的 排序 和 统计 分 析 技术 ,掌握 SQL 语句 在 数据 统计 分 析 方面 的 作用 、 设 计 
方法 及 要 领 ,增强 用 计算 机 技术 进行 数据 统计 分 析 的 意识 ,提升 使 用 数据 库 技术 解决 实际 
应 用 问题 的 能 力 。 
二 、 实 验 任务 


(1) 输出 工业 经 济 类 (类 别 编 码 为 F4) 图 书 的 书号 、 书 名 、 出 版 社 名 称 和 定价 , 按 出 版 
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社 名 称 排序 , 当 出 版 社 名 称 相 同时 按 定价 由 高 到 低 排序 。 

(2) 输出 销售 (已 付款 ) 各 种 图 书 的 排行 榜 。 内 容 包 括 书号 、 书 名 、 销 售 册 数 、 订 单 份 
数 、 最 低 售 价 、 最 高 售 价 和 付款 金额 。 按 销售 册 数 由 高 到 低 排序 ,输出 前 5 种 书 。 

(3) 假设 书店 从 出 版 社 七 折 进 书 , 输 出 一 年 内 (365 天 ) 每 个 出 版 社 的 各 类 图 书 的 销 
售 册 数 、 销 售 额 ( 售 价 X 册 数 ) 和 毛利 润 ( 销 售 额 一 定价 X0.7X 册 数 ), 仅 输出 毛利 润 大 于 
或 等 于 100 元 的 统计 结果 。 


三 、 任务 分 析 


第 一 个 任务 是 按 条 件 检索 的 数据 排序 问题 ,排序 关键 字 分 别 是 出 版 社 名 称 和 定价 ;第 
二 个 任务 是 按 图 书 进行 分 组 统计 及 排序 分 析 问 题 , 分 组 关键 字 是 书号 ,排序 关键 字 是 销售 
册 数 。 第 三 个 任务 主要 是 多 重 分 组 (关键 字 分 别 为 出 版 社 名 称 和 类 别名 称 ) 的 数据 统计 分 
析 问 题 , 另 外 要 求 对 统计 结果 进行 筛选 。 


四 、 预 备 知 识 


(1) Order By 二 排序 关键 字 二 。 设 置 多 个 关键 字 排 序 , 只 有 前 面 的 关键 字 值 相同 时 
才 按 后 面 的 关键 字 排 序 ,并 且 每 个 排序 关键 后 可 以 加 ASC( 可 省 略 ) 或 DESC 控制 结果 数 
据 行 的 升序 或 降序 排列 。 

(2) Group By 一 分 组 关键 字 二 。 将 分 组 关键 字 值 相同 的 数据 记录 统计 成 查询 结果 
中 的 一 行 数据 ,每 个 分 组 关键 字 后 也 可 以 加 ASC( 升 序 ) 或 DESC( 降 序 ) 控 制 结果 数据 行 
的 排列 顺序 。 

(3) 统计 函数 。Group By 短语 经 常 与 AVG( 平 均值 )、Count( 记 录 个 数 )、Max( 最 大 
值 )、Min( 最 小 值 ) 和 Sum 人 (合计 ) 等 函数 结合 ,对 分 组 关键 字 进 行 数据 统计 分 析 。 


五 、 技 能 点 


(1) 选择 排序 关键 字 。Order By 短语 用 于 设置 排序 关键 字 , 当 要 求 输出 前 n 行 数据 
时 ,要 与 Limit< 行 数 志 短语 结合 。 

(2) 选择 分 组 关键 字 。 对 于 “每 个 …… 、 各 个 ……” 一 类 的 任务 要 求 ,一 般 用 Group 
By 短语 设置 分 组 关键 字 , 如 果 要 进一步 筛选 掉 统 计 结 果 中 的 部 分 数据 行 ,还 要 加 Having 
去 条 件 之 短语 。 

(3) 调用 统计 函数 。 在 Select 语句 中 可 以 调用 统计 函数 ,如 果 包 含 Group By 短语 ， 
则 基于 每 个 分 组 值 的 记录 进行 统计 ,否则 ,对 全 部 记录 进行 统计 。 


六 、 注 意 事 项 


(1) 当 Limit 与 Order By 短语 结合 时 ,输出 结果 的 数据 行 数 严 格 受 到 Limit 短语 的 
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限制 ,因此 ,可 能 遗漏 与 最 后 一 行 同 排序 关键 字 值 的 其 他 数据 行 。 

(2) 在 含有 Group By 短语 的 Select 语句 查询 结果 中 ,只 有 统计 列 、 分 组 关键 字 能 唯 
一 确定 的 列 对 分 组 关键 字 的 值 才 有 依存 关系 。 
七 、 设计 步骤 

(1) 输出 工业 经 济 类 图 书 的 相关 信息 语句 如 下 : 

SELECT 书号 , 书 名 ,出 版 社 名 称 ， 定价 


FROM tsb 
NATURAL JOIN cbsb /* 自然 连接 , 按 出 版 社 编码 等 值 连接 * / 
WHERE 类 别 编码 = "F4" /* 工业 经 济 类 编码 为 F4* / 


ORDER BY 出 版 社 名 称 ， 定价 DESC /x* 出 版 社 名 称 相同 再 按 定 价 由 高 到 低 排列 x* / 
运行 语句 的 输出 结果 如 表 3-1 所 示 。 
表 3-1 两 个 排序 关键 字 的 查询 结果 
































书 号 书 名 出 版 社 名 称 定价 
978-7-111-47161-5 工业 4.0 即将 来 袭 的 第 四 次 工业 革命 机 械 工业 出 版 社 45.0 
978-7-302-46644-4 工业 自动 化 与 经 济 景气 指数 清华 大 学 出 版 社 36.0 
978-7-302-46650-5 工业 与 经 济 概论 清华 大 学 出 版 社 25.0 
978-7-115-41056-6 社 群 粉丝 经 济 玩 转 法 则 人 民 邮 电 出 版 社 45.0 
978-7-115-40907-2 破局 传统 行业 拥抱 互联 网 十 之 策略 与 法 则 | 人 民 邮 电 出 版 社 43.0 
978-7-5086-4166-9 大 繁荣 一 一 大 众 创新 如 何 带 来 国家 繁荣 中 信 出 版 社 65.0 
978-7-5086-4664-0 创业 维 艰 一 一 如 何 完 成 比 难 更 难 的 事 中 信和 出 版 社 49.0 


从 结果 可 以 看 出 ,第 一 排序 关键 字 出 版 社 相 同 的 记录 连续 输出 ,同一 出 版 社 青 按 第 二 
排序 关键 字 定 价 由 高 到 低 输出 。 

(2) 输出 销售 各 种 图 书 排行 榜 的 语句 如 下 : 

SELECT 书号 ， 书 名 ，SUM( 册 数 ) as 销售 册 数 ， 


COUNT (预购 单 号 ) AS 订单 份 数 , MIN ( 售 价 ) as 最 低 售 价 ， 
MAX ( 售 价 ) 最 高 售 价 ，SUM ( 售 价 * 册 数 ) 付款 金额 


FROM tsb 

NATURAL JOIN ygxsb 

WHERE 付款 标记 /* 提取 付款 标记 为 非 0 的 记录 * / 
GROUP BY 书号 /* 同一 种 图 书 统计 成 一 行 结果 x* / 
ORDER BY 销售 册 数 DESC 

LIMIT 5 /* 限制 输出 前 5 行 数据 * / 


运行 语句 的 输出 结果 如 表 3-2 所 示 。 
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表 3-2 按 书 号 分 组 、 销 售 册 数 由 高 到 低 排序 结果 

















978-7-302-30505-7 | PHP 十 MySQL 网 站 开发 全 程 实例 | 546 4 41.0 | 46.0 | 2716.0 
978-7-04-041372-4 | 二 级 教程 C 语言 程序 设计 500 2 30.0 | 35.0 | 16000.0 
978-7-302-46650-5 | 工业 与 经 济 概论 450 2 23.0 | 23.0 | 10350.0 
978-7-5086-4937-5 | 世界 第 一 好 懂 的 哲学 课 100 1 35.0 | 35.0 | 3500.0 
978-7-04-044295-3 | 二 级 教程 VBasic 语言 程序 设计 80 1 50.0 | 50.0 4000. 0 




















从 结果 可 以 看 出 ,同一 书号 的 多 个 订单 统计 成 一 行 结果 ,在 “订单 份 数 ” 列 中 给 出 同一 


书号 的 订单 份 数 统计 结果 ; 书 名 是 书号 能 唯一 确定 的 列 。 
(3) 输出 一 年 内 每 个 出 版 社 的 各 类 图 书 销售 毛利 润 的 语句 如 下 : 


SELECT 出 版 社 名 称 , 类 别名 称 ， 
SUM ( 册 数 ) Rs 销售 册 数 ,suM ( 售 价 * 册 数 ) 销售 金额 ， 
SUM( 售 价 x* 册 数 -定价 * 0.7* 册 数 ) Rs 毛利 润 
FROM cbsb 
NATURAL JOIN TSB 
NATURAL JOIN 1bb 
NATURAL JOIN ygxsb 
WHERE 付款 标记 
AND DATEDIFF (CURDATE () ， 预 购 日 期 ) <=365 


/= 自然 连接 , 按 书 号 等 值 连接 * / 


GROUP BY 出 版 社 名 称 ASC， 类 别名 称 DESC /* 分 组 关键 字 也 为 排序 关键 字 * / 
/* 过 滤 掉 毛利 润 少 于 100 的 数据 行 * / 


HAVING 毛利 润 > =100 
运行 语句 的 输出 结果 如 表 3-3 所 示 。 
表 3-3 两 个 分 组 关键 字 的 统计 表 


/* 自然 连接 , 按 出 版 社 编码 等 值 连接 * / 
/* 自然 连接 , 按 类 别 编码 等 值 连接 * / 























出 版 社 名 称 类 别名 称 销售 册 数 销售 金额 毛利 润 
电子 工业 出 版 社 自动 化 技术 .计算 技术 25 1625.0 487.5 
高 等 教育 出 版 社 自动 化 技术 .计算 技术 580 20000.0 4950.0 
机 械 工业 出 版 社 自动 化 技术 .计算 技术 35 1485.0 445.5 
清华 大 学 出 版 社 自动 化 技术 .计算 技术 571 23796.0 3922. 4 
清华 大 学 出 版 社 工业 经 济 450 10350.0 2475.0 
中 信 出 版 社 哲学 理论 100 3500.0 1050.0 
中 信和 出 版 社 工业 经 济 10 650.0 195.0 














从 结果 可 以 看 出 ,两 个 关键 字 值 均 相同 的 记录 统计 成 一 行 结果 , 即 ,两 个 关键 字 组 合 


分 组 。 


从 表 3-3 的 结果 来 看 ,并 没有 统计 出 一 级 分 组 (出 版 社 名 称 ) 的 有 关 数 据 , 要 实现 这 类 
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统计 ,还 需要 在 语句 中 加 With RollUp 短语 。 修 改 后 的 语句 如 下 : 


SELECT IfNu11 (出 版 社 名 称 ," 总 计 ") 出 版 社 名 称 , IfNu11 (类 别名 称 ,"") 类 别名 称 ， 
SUM( 册 数 ) As 销售 册 数 ，SUM ( 售 价 * 册 数 ) 销售 金额 ， 
SUM ( 售 价 * 册 数 -定价 * 0.7* 册 数 ) Rs 毛利 润 


FROM cbsb 

NATURAL JOIN TSB /< 自然 连接 , 按 出 版 社 编码 等 值 连接 * / 
NATURAL JOIN 1bb /* 自然 连接 , 按 类 别 编码 等 值 连接 * / 
NATURAL JOIN ygxsb /= 自然 连接 , 按 书 号 等 值 连接 * / 


WHERE 付款 标记 

AND DATEDIFF (CURDATE () ， 预 购 日 期 ) <=365 

GROUP BY 出 版 社 名 称 ASC， 类 别名 称 DESC “”/* 两 个 分 组 关键 字 * / 

WITH ROLLUP /* 增加 分 组 合计 和 总 计 行 * / 

HAVING 毛利 润 >=100 /* 过 滤 掉 毛利 润 少 于 100 的 数据 行 * / 


调用 INull 函数 将 总 计 行 和 出 版 社 分 组 行 的 Null 值 转换 成 字符 串 。 运 行 语句 的 输 
出 结果 如 表 3-4 所 示 。 


表 3-4 含 一 级 关键 字 出 版 社 的 分 组 统计 表 












































出 版 社 名 称 类 别名 称 销售 册 数 销售 金额 毛利 润 
电子 工业 出 版 社 自动 化 技术 .计算 技术 25 1625.0 487.5 
电子 工业 出 版 社 25 1625.0 487.5 
高 等 教育 出 版 社 自动 化 技术 、 计 算 技 术 580 20000.0 4950.0 
高 等 教育 出 版 社 580 20000.0 4950.0 
机 械 工 业 出 版 社 自动 化 技术 、 计 算 技术 15 1485.0 445.5 
机 械 工业 出 版 社 15 1485.0 445.5 
清华 大 学 出 版 社 自动 化 技术 .计算 技术 571 23796.0 3922. 4 
清华 大 学 出 版 社 工业 经 济 450 10350.0 2475.0 
清华 大 学 出 版 社 1021 34146.0 6397.4 

哲学 理论 100 3500.0 1050.0 
工业 经 济 10 650.0 195.0 
中 信 出 版 社 110 4150. 0 1245. 0 
总 计 1754 61583.0 13578.5 














从 结果 可 以 看 出 , 先 给 出 两 个 分 组 关键 字 的 组 合 统计 ,然后 给 出 一 级 关键 字 出 版 社 的 
分 组 统计 ;最 后 一 行 给 出 总 计 结 果 。 


八 、 思 考题 


(1) Order By 和 Group By 短语 中 均 可 以 加 ASC 或 DESC 控制 结果 数据 行 的 顺序 。 


(62) 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


在 含有 Group By 短语 的 Select 语句 中 ,要 使 统计 结果 数据 行 有 序 ,什么 情况 下 可 以 不 用 
Order By 短语 ?什么 情况 下 必须 用 Order By 短语 ? 

(2) IINull( 类 别名 称 ,"”) 对 表 3-4 中 的 哪些 数据 行 有 影响 ? 还 能 调用 其 他 哪些 函 
数 代 蔡 IfNull 函数 的 功能 ? 

(3) 在 完成 第 2 个 任务 的 语句 基础 上 ,如 何 计 算 每 种 书 的 平均 售 价 ? 在 完成 第 3 个 
任务 的 语句 基础 上 ,如 何 计算 毛利 率 ( 毛 利润 /销售 金额 X100)? 

(4) Where 一 条 件 过 和 Having 二 条 件 过 都 能 起 筛选 数据 行 的 作用 ,二 者 有 何 区 别 ? 
各 自 适 用 于 什么 情况 ? 


3.5 SQL 语句 的 幅 套 设计 
一 、 实验 目的 


学 习 SQL 语句 的 嵌 套 设计 技术 ,掌握 SQL 语句 的 榜 套 位 置 、 运 行 过 程 和 作用 ,以 便 
利用 嵌 套 技术 解决 更 复杂 的 实际 应 用 问题 。 


二 、 实 验 任务 


(1) 按 出 版 社 名 称 和 书 名 排序 输出 近 30 天 滞销 图 书 的 书号 、 书 名 和 出 版 社 名 称 。 

(2) 按 定价 由 高 到 低 排序 ,输出 各 类 定价 最 高 图 书 的 类 别名 称 、 出 版 社 名 称 、 书 号 、 书 
名 和 定价 。 

(3) 按 书 名 排序 输出 重 书 名 的 书号 、 书 名 、 出 版 社 名 称 和 定价 , 同 书 名 时 按 定价 降序 
排列 。 

(4) 根据 会 员 的 购书 情况 ,填写 每 个 会 员 的 累计 购书 金额 .累计 购书 册 数 和 最 近 购 书 
日 期 。 

(5) 用 嵌 套 的 Select 语句 输出 书号 、 书 名 和 类 别名 称 。 


三 、 任务 分 析 


第 一 个 任务 实质 是 查找 在 预购 销售 表 ygxsb 中 近 30 天 没有 发 生 付款 的 图 书 。 第 二 
个 任务 是 查找 各 类 最 高 定价 的 图 书信 息 。 第 三 个 任务 是 查找 书 名 相同 而 书号 不 同 的 图 书 
信息 。 这 三 个 任务 都 能 通过 Where 二 条 件 表达 式 二 中 嵌 套 子 查询 来 实现 。 

第 四 个 任务 需要 在 Update 一 表 名 之 Set 二 字段 名 之 = 二 表达 式 过 中 内 套 子 查询 。 
第 五 个 任务 要 求 在 Select 一 表达 式 二 中 内 套 子 查询 。 
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四 、 预 备 知识 


(1) 子 查 询 常 用 谓词 。[ Not] In、All.Any|Some 和 [Not]Exists。 

(2) 子 查询 的 嵌 套 位 置 。 可 以 嵌 套 在 以 Update、Delete 和 Select 为 主语 句 的 表达 式 中 ， 
具体 谍 套 在 Select 一 表达 式 二 、Where<< 条 件 表达 式 之 或 Update … Set 二 字段 名 二 = 二 表 
达 式 二 中 。 


五 、 技 能 点 


(1) 子 查 询 设计 。 与 独立 执行 的 Select 语句 有 些 差异 , 绝 大 多 数 子 查询 的 结果 为 一 
个 或 一 列 数据 。 多 数 子 查询 中 引用 主 SQL 语句 中 的 数据 ,因而 不 能 独立 执行 。 

(2) 选择 子 查询 运算 符 。 子 查询 结果 为 一 个 数据 ( 含 Null) 时 ,可 以 视 为 一 个 普通 数 
据 ,进行 算术 运算 .比较 运算 .逻辑 运算 或 作为 函数 的 参数 ; 当 子 查询 结果 为 数据 集 时 , 必 
须 用 集合 谓词 运算 符 [Not] In、All、.Any|Some 或 LNot]Exists 。 


六 、 注 意 事项 


(1) 子 查询 语句 必须 用 小 括号 括 起 来 , 嵌 套 在 主 SQL 语句 的 表达 式 中 。 

(2) 当 子 查询 结果 为 数据 集 时 ,不 能 用 常规 运算 符 对 其 进行 运算 ,否则 ,系统 出 错 。 

(3) 当主 语句 为 Update 或 Delete 时 , 子 查 询 的 数据 源 不 能 是 主语 句 中 正 处 理 的 数 
据 表 。 


七 、 设 计 步 又 


(1) 输出 近 30 天 滞销 图 书 ,语句 如 下 : 


SELECT 书号 , 书 名 , 出 版 社 名 称 ， 定价 
FROM tsb 
NATURAL JOIN cbsb /* 自然 连接 , 按 出 版 社 编码 等 值 连接 * / 
WHERE 书号 NOT IN 
(/* 能 套 的 子 查询 语句 必须 用 小 括号 括 起 来 * / 
SELECT 书号 
FROM Ygxsb 
WHERE 付款 标记 
AND DATEDIFF (CURDATE () ,预购 日 期 ) <=30 
) /* 嵌 套 的 子 查询 结束 * / 
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(2) 输出 各 类 定价 最 高 的 图 书 : 


SELECT 类 别名 称 ， 出 版 社 名 称 ， 书 号 ， 书 名 ,定价 
FROM cbsb 
NATURAL JOIN tsb AS ts 
NATURAL JOIN 1bb 
WHERE 定价 = (/* 子 查询 结果 为 一 个 数据 ,因此 ,可 以 用 常规 运算 符 "="* / 
SELECT MAX (定价 ) /* 取 当 前 类 中 的 最 高 定价 * / 
FROM tsb 
WHERE tsb. 类 别 编码 =ts. 类 别 编码 
. 
ORDER BY 定价 DESC 


运行 语句 的 输出 结果 如 表 3-5 所 示 。 
表 3-5 各 类 定价 最 高 的 图 书 


/* 为 tsb 另 起 别名 ts, 以便 子 查询 中 引用 */ 

















类 别名 称 出 版 社 名 称 书 号 书 : “省 定价 
自动 化 技术 、 计 算 技 术 | 机 械 工业 出 版 社 | 978-7-111-38074-0 | C 程序 设计 的 抽象 思维 99.0 
工业 经 济 中 信 出 版 社 978-7-5086-4166-9 人 65.0 
政治 经 济 学 中 信 出 版 社 978-7-5086-4721-0 | 第 二 次 机 器 革命 59.8 
金融 中 国 金融 出 版 社 | 978-7-5049-6590-5 | 经 典 金融 故事 汇 59.0 
哲学 理论 清华 大 学 出 版 社 | 978-7-302-35506-9 | 自然 辩证 法 概论 42.0 














用 谓词 ALL 对 子 查 询 进行 运算 ,也 可 以 产生 相同 的 效果 : 


SELECT 类 别名 称 , 出 版 社 名称 ， 书号, 书 名 , 定价 
FROM cbsb 
NATURAL JOIN tsb AS ts 
NATURAL JOIN lbb 
WHERE 定价 >=ALL ( 


/* 为 tsb 另 起 别名 ts, 以 便 子 查询 中 引用 * / 


/* 子 查询 结果 为 数据 集 , 必 须 用 谓词 运算 符 * / 
SELECT 定价 /* 取 当前 类 中 所 有 图 书 的 定价 * / 
FROM tsb 
WHERE tsb .类 别 编码 =ts. 类 别 编码 
) 


ORDER BY 定价 DESC 
(3) 输出 重 书 名 的 图 书信 息 ,语句 如 下 : 


SELECT 书号 , 书 名 , 出 版 社 名 称 ， 定价 
FROM cbsb 
NATURAL JOIN tsb AS ts 
WHERE EXISTS ( 
SELECT * 
FROM tsb 





/* 为 tsb 另 起 别 名 ts, 以便 子 查询 中 引用 * / 
/* 子 查询 结果 为 数据 集 , 必 须 用 谓词 运算 符 * / 
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WHERE tsb. 书 名 =ts. 书 名 
AND tsb .书号 <>ts .书号 
) 
ORDER BY 书 名 ， 定 价 DESC 


(4) 填写 会 员 的 有 关 购 书信 息 的 语句 : 


UPDATE hyb SET 累计 购书 金额 = (SELECT SUM( 售 价 * 册 数 ) 

FROM ygxsb /* 子 查询 结果 作 字 段 的 值 * / 
WHERE hyb .会 员 账号 =ygxsb .会 员 账 号 
AND 付款 标记 )， 

累计 购书 数量 = (SELECT SUM ( 册 数 ) 
FROM ygxsb 
WHERE hyb .会 员 账号 =ygxsb .会 员 账 号 
AND 付款 标记 )， 

最 近 购 书 日 期 = (SELECT MAX (预购 日 期 ) 


FROM ygxsb 
WHERE hyb .会 员 账号 =ygxsb .会 员 账 号 
AND 付款 标记 ) 
(5) 用 嵌 套 Select 语句 输出 书号 、 书 名 和 类 别名 称 。 
SELECT 书号 ， 书 名 ，( /* 子 查询 结果 作为 Select< 表 达 式 >* / 
SELECT 类 别名 称 
FROM 1bb 
WHERE 1bb. 类 别 编码 =tsb. 类 别 编码 
) AS 类 别名 称 
FROM tsb 
ORDER BY 类 别名 称 


八 、 思 考题 


(1) 运行 下 列 语句 : 


SELECT 类 别名 称 ， 出 版 社 名 称 ， 书 号 ， 书 名 ，max (定价 ) AS 定价 
FROM cbsb /<*3 个 表 自然 连接 * / 
NATURAL JOIN tsb AS ts 
NATURAL JOIN 1bb 
GROUP BY 类 别名 称 /* 按 类 别名 称 分 组 * / 
ORDER BY 定价 DESC /* 按 定价 由 高 到 低 排序 * / 


以 上 语句 的 查询 结果 与 第 2 个 任务 的 查询 结果 (如 表 3-5 所 示 ) 比 较 , 有 什么 区 别 ? 
这 条 语句 是 否 能 完成 第 2 个 任务 ? 

(2)“SELECT 书号 , 书 名 ,类 别名 称 FROM tsb NATURAL JOIN lbb” 与 完成 第 5 
个 任务 的 语句 比较 ,功能 是 否 相 同 ? 哪 条 语句 运行 时 间 效 率 更 高 ? 
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(3) 在 完成 第 2 个 任务 的 两 条 语句 中 ,如 果 将 与 子 查询 的 运算 符 “ 一 ”和 ”之 一 ALL” 
对 换 , 则 会 产生 什么 效果 ? 由 此 得 到 什么 结论 ? 


3.6 SQL 语句 的 合并 设计 


一 、 实 验 目的 


测试 多 条 SQL 语句 的 合并 效果 ,了 解 其 功能 范畴 ,掌握 SQL 语句 的 综合 设计 技术 ， 
以 便 灵 活 地 运用 数据 库 技 术 进行 数据 维护 和 统计 分 析 。 


二 、 实验 任 务 


(1) 将 预购 销售 表 (ygxsb) 中 的 数据 备份 到 预购 销售 备份 表 中 。 

(2) 将 会 员 的 购书 统计 数据 存储 到 会 员 统计 表 (hytib) 中 。hytib 中 字段 包括 会 员 账 
号 Char(10)( 主 关键 字 )、 姓 名 VarChar(20) ,付款 金额 Int(7) 购书 册 数 Int(5) 和 购书 订 
单数 Int(5) 。 

(3) 在 一 个 查询 结果 中 输出 图 书 预购 销售 册 数 排行 榜 前 、 后 各 三 名 (包括 无 销售 ) ,内 
容 包括 书号 、 书 名 和 册 数 (无 销售 ,为 0)。 


三 、 任务 分 析 


第 一 个 任务 需要 Create Table 子 句 与 Select 子 句 合并 ,Create Table 子 句 用 于 创建 
预购 销售 备份 表 , Select 子 句 用 于 提取 ygxsb 中 的 全 部 记录 和 字段 。 

第 二 个 任务 ,由 于 对 新 表 hytjb 中 的 字段 与 已 有 的 字段 宽度 及 类 型 要 求 有 所 不 同 , 并 
且 有 关键 字 , 因 此 ,需要 在 Create Table 语句 中 明确 说 明 表 的 主 关 键 字 、 各 个 字段 类 型 和 
宽度 。 可 以 用 独立 的 Create Table 语句 创建 表 , 再 用 Replace 或 Insert 子 句 与 Select 子 
名 合并 两 步 完 成 ,也 可 以 用 Create Table 与 Select 子 句 直接 合并 成 一 步 完 成 。 

第 三 个 任务 用 两 条 按 书 号 分 组 查询 的 语句 合并 即 可 ,但 由 于 可 能 有 无 销售 的 图 书 , 因 
此 ,要 考虑 tsb 与 ygxsb 的 连接 类 型 选择 为 LEFT JOIN。 另 外 ,两 条 子 语 句 的 差异 仅 在 
于 排序 方式 ( 升 或 降序 ) 。 


四 、 预 备 知识 


SQL 语句 合并 主要 有 如 下 3 种 方式 : 

(1) 创建 表 与 查询 语句 合并 。 志 Create Table 子 句 > [As] 二 Select 子 句 二 ,将 查询 
的 结果 数据 存 于 新 表 中 。 

(2) 插入 与 查询 语句 合并 。Replace | Insert[Into] 一 表 名 >[(< 天 字段 名 表 >)] 
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去 Select 子 句 之 ,将 查询 的 结果 存 到 已 存在 的 表 中 ,Select 子 句 不 会 改变 表 结 构 。 
(3) 两 条 查询 语句 合并 。 二 Select 子 句 1] 定 UnionLAIJ] 一 Select 子 句 2 二 ,将 两 个 查 
询 结果 的 数据 行 合并 成 一 个 查询 结果 。 


五 、 技 能 点 


(1) 选择 SQL 语句 的 合并 方式 。 恰 当地 选择 合并 方式 创建 表 与 查询 .增加 记录 与 查 
询 或 查询 子 句 合并 ,设计 符合 任务 要 求 的 合并 语句 。 
(2) 设计 SQL 子 语句 。 子 语句 可 以 是 Create Table、Replace、Insert 或 Select。 


六 、 注 意 事项 


(1) 如 果 合并 结果 表 已 经 存在 , 则 应 该 用 "Replace| Insert[LInto] 志 表 名 之 [( 到 字段 
名 表 二 )] 一 Select 子 句 二 ”, 不 能 用 “二 Create Table 子 句 描述 二 [As] 一 Select 子 句 描 
述 二 ”, 因 为 后 者 会 出 错 。 

(2) 两 条 子 语句 中 对 应 列 的 数据 类 型 可 以 不 同 ,但 是 ,数据 类 型 之 间 必 须 可 以 自动 
转换 。 


七 、 设 计 步 又 


(1) 将 表 ygxsb 备份 到 预购 销售 备份 表 的 语句 如 下 : 


CREATE TABLE 预购 销售 备份 表 /* 字 段 及 属性 由 查询 结果 决定 ,并 没有 关键 字 * / 
AS SELECT * FROM ygxsb 


(2) 生成 会 员 统 计 表 (hytjb) 的 两 条 语句 如 下 : 


CREATE TABLE hytjb /* 创建 表 的 独立 语句 * / 
( 
会 员 账号 Char (10) PRIMARY KEY, 姓名 VarChar (20)， 
付款 金额 Int (7) ,购书 册 数 Int (5) ,购书 订单 数 Int (5) 


INSERT INTO hytjb /x* INSERT 与 SELECT 合并 语句 * / 
SELECT 会 员 账号 ， 姓 名 ，SUM ( 售 价 x 册 数 )，SUM ( 册 数 ),COUNT (预购 单 号 ) 
FROM hyb 
NATURAL JOIN ygxsb 
WHERE 付款 标记 /* 付款 标记 非 0 的 记录 */ 


GROUP BY 会 员 账 号 
另 一 种 设计 方法 用 一 条 语句 : 
CREATE TABLE hytjb /* 创建 表 的 子 语句 * / 
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会 员 账号 char (10) PRIMARY KEY， 姓 名 VarChar (20)， 
付款 金额 Int (7)， 购书 册 数 Int (5) ， 购 书 订单 数 Int (5) 
RS 
SELECT 会 员 账号 ， 姓 名 ，SUM ( 售 价 * 册 数 ) 付款 金额 ， /=* 数 据 统计 子 语 句 * / 
SUM( 册 数 ) 购书 册 数 ,COUNT (预购 单 号 ) 购书 订单 数 
FROM hyb NATURAL JOIN ygxsb 
WHERE 付款 标记 
GROUP BY 会 员 账 号 


(3) 查询 图 书 销售 册 数 排行 榜 前 、 后 各 三 名 的 语句 如 下 : 


( 
SELECT tsb .书号 , 书 名 ， 
IFNULL (SUM( 册 数 ),0) AS 册 数 /* 无 销售 图 书 的 SUM ( 册 数 ) 为 Nullx / 
FROM tsb 
LEFT JOIN ygxsb ON tsb. 书 号 =ygxsb. 书 号 
GROUP BY tsb. 书 号 
ORDER BY 册 数 DESC LIMIT 3 /* 册 数 由 高 到 低 排序 前 三 名 的 子 语句 * / 
UNION 
( 
SELECT tsb .书号 , 书 名 ，IFNULL (SUM( 册 数 ) ，0) AS 册 数 
FROM tsb 
LEFT JOIN ygxsb ON tsb. 书 号 =ygxsb. 书 号 
GROUP BY tsb. 书 号 
ORDER BY 册 数 LIMIT 3 /=* 册 数 由 低 到 高 排序 前 三 名 的 子 语句 * / 


八 、 思 考题 


(1) SQL 语句 的 合并 有 哪些 方式 ”这 些 方式 各 自 适合 完成 哪 类 任务 ? 

(2) 在 SQL 语句 的 各 种 合并 方式 中 ,如 果 两 个 子 语句 的 列 数 不 一 致 ,或 者 对 应 的 数 
据 类 型 及 宽度 不 一 致 ,系统 将 如 何 处 理 ? 

(3) SQL 语句 嵌 套 和 合并 都 是 将 多 条 语句 组 合成 一 条 语句 ,二 者 有 哪些 异同 ? 赃 套 
的 语句 是 否 可 以 再 合并 ? 


3.7 视图 的 创建 及 应 用 


一 、 实验 目 的 


了 解 视图 的 构造 方法 ,学 会 视图 的 应 用 过 程 及 用 途 , 以 便 解 决 更 复杂 的 实际 应 用 问题 
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时 思路 更 清晰 ,语句 更 简捷 。 
二 、 实 验 任务 


创建 一 个 通用 视图 对 象 “销售 统计 ”, 用 以 完成 下 列 任务 : 

(1) 输出 各 种 图 书 的 书号 、 书 名 、 定 价 和 平均 售 价 。 

(2) 假设 书店 从 出 版 社 七 折 进 书 , 输 出 各 个 出 版 社 每 类 图 书 的 销售 册 数 小 计 、 销 售 金 
额 小 计 , 毛 利润 小 计 ( 销 售 金额 一 定价 X0.7X 销 售 册 数 ) 和 毛利 率 (毛利 润 小 计 / 销 售 金额 
小 计 X100) , 仅 输出 毛利 润 小 计 大 于 或 等 于 500 元 的 统计 结果 。 

(3) 输出 售 价 高 于 所 购 图 书 平均 售 价 的 预购 单 号 、 书 号 、 购 买 册 数 、 售 价 、 平 均 售 价 、 
会 员 账 号 和 姓名 , 按 售 价 与 平均 售 价 的 差 值 由 高 到 低 排 序 。 


三 、 任务 分 析 


这 三 个 任务 都 涉及 对 查询 结果 的 计算 列 再 次 进行 运算 的 问题 ,对 于 wssd 数据 库 中 
的 表 , 要 解决 平均 售 价 和 毛利 率 等 问题 ,都 需要 多 条 SQL 语句 或 嵌 套 才能 完成 ,通过 创建 
一 个 公共 视图 ,更 便于 这 类 问题 的 解决 。 


四 、 预 备 知识 


创建 视图 的 基本 语句 格式 : 


Create [ Or Replace ] View < 视图 名 > [( 列 名 称 表 ) ] 
Rs <Select 子 句 > 


五 、 技 能 点 


(1) 创建 视图 。 关 键 在 于 设计 Select 语句 ,巧妙 地 设计 视图 可 以 使 视图 具有 通用 性 ， 
简化 问题 的 求解 过 程 。 

(2) 应 用 视图 。 视 图 与 数据 表 类 似 , 可 以 作为 SQL 语句 的 数据 源 , 充 分 利用 视图 ,可 
以 使 复杂 问题 简化 , 解 题 思路 更 清晰 。 


(1) 列 名 称 表 中 的 列 数 要 与 Select 子 句 查 询 结果 中 的 列 数 一 致 ,并 按 前 后 顺序 一 一 


对 应 。 
(2) 当 省 略 列 名 称 表 时 ,视图 中 的 列 数 及 各 列 名 称 由 Select 子 句 的 查询 结果 来 确定 。 


基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


七 、 实 验 步 又 


1. 创建 视图 “销售 统计 ” 


(1) 进入 SQL 语句 编辑 窗口 。 在 PHPMyAdmin 的 主页 , 单 击 数据 库 名 wssd 习 数据 
表 名 tsb 一 代码 编辑 工具 “编辑 ”。 
(2) 编辑 创建 视图 的 语句 。 在 SQL 语句 编 辑 框 中 ,输入 如 下 语句 : 


CREATE VIEW 销售 统计 As /= 创建 视图 "销售 统计 "* / 
SELECT 书号 ，SUM ( 册 数 ) 销售 册 数 ，SUM{( 售 价 x 册 数 ) AS 销售 金额 
FROM ygxsb WHERE 付款 标记 
GROUP BY 书号 /* 统计 每 种 图 书 的 销售 情况 * / 


(3) 创建 视图 销售 统计 。 单 击 SQL 语句 编辑 窗口 中 的 “执行 "按钮 ,在 数据 库 wssd 
中 增加 了 一 个 “销售 统计 ”视图 。 


2. 应 用 “销售 统计 ”视图 进行 数据 统计 分 析 
(1) 输出 各 种 图 书 的 书号 . 书 名 ,定价 和 平均 售 价 的 语句 如 下 : 


SELECT 书号 , 书 名 , 定价， 
销售 金额 /销售 册 数 AS 平均 售 价 /* 引用 视图 "销售 统计 "中 的 计算 列 * / 
FROM tsb NATURAL JOIN 销售 统计 /* 将 视图 "销售 统计 "作为 数据 源 * / 


(2) 输出 各 个 出 版 社 每 类 图 书 销售 情况 的 语句 如 下 : 


SELECT 出 版 社 名 称 ， 类 别名 称 ， 
SUM (销售 册 数 ) as 销售 册 数 小 计 ， /x* 引用 视图 "销售 统计 "中 的 计算 列 * / 
SUM (销售 金额 ) As 销售 金额 小 计 ， /x* 引用 视图 "销售 统计 "中 的 计算 列 * / 
SUM (销售 金额 -定价 * 0.7* 销售 册 数 ) as 毛利 润 小 计 ， 
SUM (销售 金额 -定价 * 0.7* 销售 册 数 ) /SUM (销售 金额 ) * 100 as 毛利 率 
FROM cbsb NATURAL JOIN tsb NATURAL JOIN lbb 

NATURAL JOIN 销售 统计 /< 将 视图 "销售 统计 "作为 数据 源 * / 

GROUP BY 1，2 HAVING 毛利 润 小 计 >=500 


(3) 输出 售 价 高 于 所 购 图 书 平均 售 价 的 预购 单 号 信息 ,语句 如 下 : 


SELECT 预购 单 号 , 书号 , 册 数 AS 购买 册 数 ， 售 价 ， 
销售 金额 /销售 册 数 As 平均 售 价 , 会 员 账 号 , 姓名 
FROM ygxsb NATURAL JOIN hyb 
NATURAL JOIN 销售 统计 /=* 将 视图 "销售 统计 "作为 数据 源 * / 
HAVING 售 价 > 平均 售 价 
ORDER BY 和 售 价 -平均 售 价 DESC 
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S 


并 思考 题 


(1) 数据 表 和 视图 都 可 以 作为 SQL 语句 的 数据 源 , 二 者 的 作用 有 哪些 区 别 ? 在 什么 
情况 下 应 用 视图 更 方便 ? 
(2) 将 完成 第 2 个 任务 的 语句 简化 为 下 列 语句 会 引发 什么 问题 ? 主要 是 由 于 修改 哪 
些 内 容 引 发 的 问题 ? 
SELECT 出 版 社 名 称 ， 类 别名 称 ， 
SUM (销售 册 数 ) as 销售 册 数 小 计 ， 
SUM (销售 金额 ) AS 销售 金额 小 计 ， 
SUM (销售 金额 -定价 * 0.7* 销售 册 数 ) as 毛利 润 小 计 ， 
毛利 润 小 计 / 销 售 金额 小 计 * 100 as 毛利 率 
FROM cbsb NATURAL JOIN tsb NATURAL JOIN lbb NATURAL JOIN 销售 统计 
GROUP BY 1，2 HAVING 毛利 润 小 计 >=500 


(3) 能 否 将 完成 相关 任务 语句 中 的 HAVING 改 为 WHERE 短语 ? 为 什么 ? 
3.8 数据 表 中 数据 的 导入 /导出 


一 、 实 验 目 的 


掌握 数据 库 管理 系统 CDBMS) 与 其 他 软件 的 数据 交换 方法 ,以 便 灵 活 应 用 DBMS 和 
其 他 软件 进行 综合 业务 处 理 ,提高 数据 的 重用 性 共享 性 和 工作 效率 。 


二 、 实 验 任务 


创建 E:\W 一 学 号 > 文件 夹 ,如 E:N\W99150101 ,将 完成 下 列 任务 的 相关 文件 存储 到 
该 文件 夹 中 。 

(1) E:\ W99150101\cbstmp. txt 文件 内 容 如 下 ,将 其 导入 到 表 cbsb 中 。 

02, 人 民 文 学 出 版 社 

5004, 中国 社会 科学 出 版 社 

5601, 吉林 大 学 出 版 社 

80234, 中 国 发 展 出 版 社 

(2) 将 表 tsb 中 的 数据 记录 导出 到 文件 E:\W99150101\tsb. xls 中 。 

(3) 将 表 cbsb 中 出 版 社 名称 含 “大 学 "两 个 字 的 数据 记录 以 表格 的 形式 存储 到 文件 
E:\W99150101\dxcbs. doc 中 。 

(4) 将 表 lbb 中 的 数据 记录 导出 到 文件 EE:\W99150101\1bb. txt 中 ,每 个 数据 记录 占 
一 行 ,数据 项 之 间 用 空格 分 隔 。 
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芋 s 任务 分 析 


通常 用 PHPMyAdmin 相关 工具 进行 操作 ,或 者 ,执行 有 关 MySQL 语句 均 可 完成 
MySQL 数据 表 的 导入 或 导出 任务 。 但 是 ,通过 PHPMyAdmin 的 工具 导入 /导出 数据 时 ， 
很 难 控制 数据 的 内 容 ( 如 包含 哪些 记录 、 是 否 含 表 结构 等 ) 和 格式 (如 数据 项 之 间 的 分 隔 
符 )。 因 此 ,通常 运行 MySQL 语句 实现 数据 表 的 导入 /导出 会 更 灵活 一 些 。 


四 、 预 备 知识 


(1) 导入 数据 的 语句 : 


Load Data InFile< 文 件 路 径 及 文件 全 名 >Into Table< 表 名 > 
[Fields [Terminated By'< 数 据 项 分 隔 符 >'] 
[ENClosed By '< 数 据 项 包裹 符 > ']] 
[Lines Terminated By'< 数 据 行 分 隔 符 >'] 
[(< 字 段 名 表 >)] 
(2) 导出 数据 的 语句 : 
Select … Into OutFile< 文 件 路 径 及 文件 全 名 > 
[Fields [Terminated By'< 数 据 项 分 隔 符 >'] 
[ENClosed BY '< 数 据 项 包裹 符 > '] ] 
[Lines Terminated By'< 数 据 行 分 隔 符 > '] 


五 、 技 能 点 


(1) 导入 /导出 数据 的 语句 设计 。 根 据 数据 格式 的 要 求 ,正确 运用 相关 短语 设计 
Load Data InFile 和 Select … Into OutFile 语句 。 

(2) 编辑 和 整理 数据 格式 。 对 导出 的 数据 ,需要 使 用 相关 软件 进一步 编辑 和 整理 ,以 
便 数 据 格式 完全 满足 实际 应 用 的 要 求 。 对 要 导入 的 数据 , 先 要 按 规范 的 格式 (如 数据 项 的 
分 隔 符 、 包 里 符 等 ) 整 理 数 据 , 随 后 才能 进行 导入 操作 。 


六 、 注 意 事项 

(1) 导入 数据 时 ,被 导入 的 数据 格式 一 定 要 规范 ,否则 ,可 能 导致 系统 出 错 、 数 据 窒 
项 ,数据 丢失 或 出 现 空 记录 等 问题 。 

(2) 导出 的 数据 格式 可 能 不 完全 符合 要 求 , 例 如 ,直接 导出 到 txt 文件 中 的 内 容 ,所 有 


数据 记录 都 在 同一 行 上 ,需要 在 记事 本 软件 中 再 分 行 。 
(3) 导入 /导出 的 文件 类 型 由 文件 的 扩展 名 决定 。 例 如 ,txt 为 文本 文件 ,xls 为 Excel 
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表格 文件 ,doc 为 Word 文档 等 。 
(4) 文件 存储 路 径 中 的 文件 夹 名 、 文 件 名 之 间 用 正 斜 杠 符号 (/) 分 隔 , 而 不 是 反 斜 杠 
(\) ,文件 路 径 及 文件 全 名 需要 用 单 引号 或 双 引 号 引起 来 。 


七 、 实 验 步 又 
在 PHPMyAdmin 的 主页 , 单 击 数据 库 名 wssd 习 数据 表 名 cbsb 一 代码 编辑 工具 “ 编 
辑 ”, 在 SQL 语句 编辑 框 中 输入 相关 语句 。 
1. 导入 文本 文件 到 数据 表 
导入 cbsb 中 数据 记录 的 语句 如 下 : 
LOAD Data INFILE 'E:/W99150101/cbstmp.txt' 
INTO TABLE cbsb FIELDS TERMINATED BY ',' /* 数据 项 之 间 的 分 隔 符 为 半角 逗号 * / 
2. 数据 表 导 出 到 Excel 表格 文件 
将 tsb 中 的 数据 记录 导出 到 文件 EE:\W99150101\tsb. xls 的 语句 如 下 : 
SELECT * FROM tsb 
INTO OUTFILE 'E:/W99150101/tsb.xls ' /* 数 据 项 之 间 不 需要 分 隔 符 * / 
3. 数据 表 导 出 到 Word 表格 


(1) 执行 下 列 语句 ,将 cbsb 中 名 称 含有 “大 学 ”的 出 版 社 的 记录 导出 到 文件 E， 
\W99150101\dxcbs. doc 中 : 


SELECT * FROM cbsb WHERE 出 版 社 名 称 LIKE '% 大 学 %' 
INTO OUTFILE 'E:/W99150101/dxcbs .doc' 
FIELDS TERMINATED BY ' |" /* 数据 项 之 间 的 分 隔 符 为 竖 线 x / 


(2) 在 Windows 的 资源 管理 器 中 ,双击 E:\W99150101\dxcbs. doc 打开 文件 。 

(3) 在 Word 中 , 选 定 导出 后 的 全 部 内 容 , 单 击 “ 插 入 "选项 卡 一 "表格 "组 一 “表格 ”一 
“文本 转换 成 表格 选项。 

(4) 在 “将 文字 转换 成 表格 ?对话 框 中 ,选择 列 数 为 2, 固定 列 宽 为 “自动 ”, 文 字 分 隔 位 
置 为 “其 他 字符 "和 “|”, 最 后 单 击 “ 确 定 ”按钮 ,将 其 转换 成 Word 表格 。 

4. 数据 表 分 行 存储 到 txt 文件 

(1) 执行 下 列 语句 ,将 lbb 中 的 记录 导出 到 文件 E:\W99150101\tmp. doc 中 


SELECT* FROM ]bb 
INTO OUTFILE 'E:/W99150101/tmp .doc' /先导 出 到 Word 文 件 ,以 便 每 个 记录 占 一 行 * / 
FIELDS TERMINATED BY " " /* 数据 项 之 间 的 分 隔 符 为 空格 * / 
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(2) 用 Word 软件 打开 E:\W99150101\tmp. doc 文件 , 选 定 导 出 后 的 全 部 内 容 , 通 过 
“复制 "和 “粘贴 ”操作 ,将 其 粘贴 到 记事 本 软件 中 ,保存 文件 名 为 E:\W99150101\1bb. txt 
即 可 。 


八 、 思 考题 


(1) 执行 SELECT * FROM tsb INTO OUTFILE 'E:/W99150101/tmp. xls' 
FIELDS TERMINATED BY ' ' 语 句 ,tmp.xls 文件 中 的 列 与 tsb 中 的 字段 是 什么 样 的 对 
应 关系 ? 

(2) 要 将 每 种 图 书 的 书号 . 书 名 、 销 售 册 数 及 金额 导出 到 xstj.xls 文件 中 ,如 何 设计 该 
语句 ?如 果 在 导出 语句 中 加 FIELDS TERMINATED BY | 咕 语 , 导 出 的 结果 如 何 ? 

(3) 将 完成 第 4 个 任务 的 语句 改 为 SELECT x FROM lbb INTO OUTFILE 'E， 
/W99150101/1lbb. txt' FIELDS TERMINATED BY ' ', 对 生成 的 文本 文件 再 进行 哪些 操 
作 才 能 满足 任务 要 求 ? 
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第 和 单元 


MySQL 程序 设计 


MySQL 的 程序 分 为 存储 过 程 存 储 函 数 、 触 发 器 和 事件 代码 4 类 ,与 使 用 大 量 独立 
的 SQL 语句 相 比 ,使 用 程序 更 易于 代码 的 优化 、 重 用 和 维护 。 


4.1 分 支 . 循 环 结 构 程 序 设计 


一 、 实 验 目的 


理解 程序 中 分 支 结 构 和 循环 结构 的 概念 和 作用 ,掌握 定义 分 支 结 构 和 循环 结构 的 语 
名 格式 ,能 够 根据 实际 需要 设计 含有 分 支 和 循环 结构 的 程序 。 


二 、 实 验 任务 


(1) 过 程 体 中 已 经 计算 出 某 图 书 月 销售 的 册 数 并 保存 在 局 部 变量 cs 中 ,使 用 这 语句 
将 册 数 转换 为 等 级 , 即 , 册 数 超过 1000 的 属于 “畅销 书 ”, 超 过 500 且 没 超过 1000 的 属于 
“ 受 欢迎 图 书 ”, 超 过 100 且 没 超过 500 的 属于 “一 般 图 书 ”, 没 超过 100 的 属于 “滞销 图 
书 ”, 结 果 保 存在 已 声明 的 局 部 变量 csj 中 。 用 Case 语句 实现 。 

(2) 分 别 用 While、Repeat 和 Loop 结构 设计 实现 计算 1 一 1000 自然 数 之 和 的 程序 。 


三 、 任 务 分 析 











实验 (1) 需 要 使 用 分 支 结构 实现 条 件 的 判断 ,条 件 分 别 为 cs 之 1000 cs 二 500 and cs 
二 二 1000 .cs 之 100 and cs 一 一 500 和 cs 二 二 100。 实 验 (2) 需 要 使 用 循环 结构 实现 。 


四 、 预 备 知识 
1. 声明 变量 


Declare < 变量 名 1> [, 变 量 名 2[,…]] < 数据 类 型 > [Default < 表达 式 >] 


Set 变量 名 1= 表 达 式 1 [, 变 量 名 2= 表 达 式 2 [,…] ] 


2. 分 支 结构 
在 MySQL 程序 设计 中 ,有 If 和 Case 两 种 分 支 结 构 。 
(1) 工 结 构 : 


If 条 件 1 Then 语句 组 1 

[ElseIf 条 件 2 Then 语句 组 2]… 
[Else 语句 组 n ] 

End If; 


(2) Case 结构 ; 
Case 表达 式 


比较 的 值 1 Then 语句 组 1 
[比较 的 值 2 Then 语句 组 2] 


[Else 语句 组 n ] 
End Case; 


3. 循环 结构 
在 MySQL 中 常用 的 循环 有 While .Repeat 和 Loop 三 种 结构 。 
(1) While 结构 : 


[< 循环 名 >: ] While < 循环 条 件 >Do 
< 语句 组 > 
End While [< 循环 名 >] 


(2) Repeat 结构 : 


[< 循环 名 > : ] Repeat 
< 语句 组 > 
Until < 循环 条 件 > 
End Repeat [< 循环 名 >] 


(3) Loop 结构 : 


[< 循环 名 >: ] Loop 
< 语句 组 > 
End Loop [< 循环 名 >] 


五 、 技 能 点 


(1) 声明 变量 。 用 Declare 命令 定义 变量 及 数据 类 型 ,Set 命令 为 变量 赋 初 值 。 
(2) 设计 分 支 结构 程序 。 用 If…End f 或 Case…End Case 语句 实现 分 支 结构 。 
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(3) 设计 循环 结构 程序 。 用 While…End While 语句 实现 循环 结构 。 
六 、 注 意 事项 


(1) 局 部 变量 只 能 在 过 程式 数据 库 对 象 的 过 程 体 中 的 BEGIN…END 复合 语句 内 声 
明 ,并 在 其 中 使 用 。 

(2) Declare 语句 必须 是 过 程 体 的 第 一 条 语句 。 

(3) 可 以 使 用 Set 语句 直接 赋值 创建 会 话 变量 。 

(4) 【结构 使 用 End If 作为 结束 标识 ,两 者 必须 搭配 使 用 。 

(5) Leave 语句 和 Iterate 语句 应 该 用 在 循环 体 中 的 分 支 语句 内 。 


七 、 设 计 步 又 


1. If 分 支 结 构 部 分 程序 


If cs>1000 then cs= "畅销 书 "，; 
Elseif cs>500 then cs=" 受 欢迎 图 书 "; 
Elseif cs>100 then cs=" 一 般 图 书 "; 
Else cs=" 滞 销 图 书 "; 

End If; 


2. Case 分 支 结构 部 分 程序 


Case 
When cs>1000 then cs= "畅销 书 "7 
When cs>500 then cs=" 受 欢迎 图 书 "; 
When cs>100 then cs=" 一 般 图 书 "; 
Else cs= "滞销 图 书 "; 


End Case; 


3. While 循环 结构 程序 


Declare s,i int; 

Set i=1,s=0; 

While i<=1000 
Set S=S+ i; 
Set i=i+ 1; 


End While; 


4. Repeat 循环 结构 程序 


Declare s,i int; 
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Set i=1,s=0; 
Repeat 
Set s=st+t i; 
Set i=i+ 17 
Until i>1000 
End Repeat; 


5. Loop 循环 结构 程序 


Declare s,i int; 
Set i=1,s=0; 
Loop 
Set s=s+ i; 
Set i=i+ 1; 
If i>1000 Then Leave; 
End If; 
End Loop; 


八 、 思 考题 


(1) 在 定义 局 部 变量 时 ,Declare 和 Set 语句 有 什么 区 别 ? 

(2) 会 话 变 量 有 什么 作用 ? 如 何 定义 ? 

(3) 在 处 理 较 复杂 的 分 支 结构 时 ,通常 使 用 哪 种 分 支 ? 

(4) While 语句 、Repeat 语句 和 Loop 语句 有 什么 区 别 ? 是否 可 以 使 用 不 同 的 循环 结 
构 实 现 相 同 功 能 ? 


4.2 存储 过 程 设 计 


一 、 实 验 目的 


理解 存储 过 程 的 概念 和 作用 ,熟练 掌握 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 
两 种 方式 创建 ,管理 和 调用 存储 过 程 ,能 够 根据 实际 需要 设计 存储 过 程 。 


二 、 实验 任务 


(1) 在 MySQL 命令 行 创建 存储 过 程 ygxsb_sl, 根 据 会 员 账 号 参数 获取 该 会 员 近 30 
天 内 购买 图 书 的 总 册 数 。 

(2) 通过 MySQL 命令 行 调用 存储 过 程 ygxsb_sl。 

(3) 通过 PHPMyAdmin 的 可 视 化 工具 创建 存储 过 程 tsb_zl, 根 据 定价 参数 获取 图 书 
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定价 低 于 或 等 于 该 参数 的 图 书 种 数 。 

(4) 通过 PHPMyAdmin 的 可 视 化 工具 调用 存储 过 程 tsb_zl。 

(5) 通过 PHPMyAdmin 的 可 视 化 工具 修改 存储 过 程 tsb_zl, 根 据 两 个 定价 参数 金额 
获取 图 书 定价 介 于 两 个 参数 之 间 的 图 书 种 数 。 

(6) 通过 PHPMyAdmin 的 可 视 化 工具 创建 存储 过 程 ygxsb_tj, 用 于 统计 ygxsb 表 
中 不 同 状态 的 图 书 册 数 。 


三 、 任务 分 析 


设计 存储 过 程 ,可 以 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 。 存 
储 过 程 ygxsb_sl 和 tsb_zl 需要 定义 输入 ,输出 参数 ,接收 数据 并 返回 值 ;存储 过 程 ygxsb_ 
tj 由 于 要 获取 表 中 多 行 数据 ,所 以 需要 定义 游标 并 且 使 用 分 支 . 循 环 结构 实现 。 


四 、 预 备 知识 


(1) 创建 存储 过 程 语句 格式 : 

Create Procedure [< 数据 库 名 > .]< 存 储 过 程 名 >([Inlout1Inout < 形式 参数 名 1>< 数 据 类 型 
1>i[…]]) 

(2) 定义 .打开 、. 读 取 游标 语句 格式 : 

Declare < 游标 名 称 >Cursor For <Select 语句 > 

Open < 游标 名 称 > 

Fetch < 游标 名 称 >Into < 变量 名 1> [,< 变 量 名 2>…] 

(3) 调用 存储 过 程 语句 格式 : 

call [数据 库 名 . ]< 存 储 过 程 名 >( [ 实际 参数 1 [,…] ] )) 


(4) PHPMyAdmin 创建 存储 过 程 : 在 PHPMyAdmin 的 主页 中 选择 当前 数据 库 名 
(如 wssd) ,选择 “程序 ”选项 卡 中 的 “添加 程序 ”按钮 ,进入 MySQL 存储 过 程 的 编辑 窗口 ， 
如 图 4-1 所 示 。 


五 、 技 能 点 


(1) 创建 存储 过 程 。 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 均 可 创建 存储 

(2) 定义 .打开 、 读 取 游 标 。 用 Declare、Open 和 Fetch 命令 分 别 定义 、 打 开 和 读 取 
游标 。 

(3) 调用 存储 过 程 。 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 均 可 调用 存储 
过 程 。 
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存储 过 程 名 。 过 程 标识 
| | 





添加 程序 | 
详细 
程序 名 称 tsb_zl 
类型 PROCEDURE v 
方向 ”名字 关 型 长 度 / 值 选项 
每 数 ] "||price INT MM | © i 
1 了 ||a INT MM "| © Wt 





Begin 
Select Count (+) Into zl From tsb Yhere 定价 <=price 
End 
代码 编辑 窗口 一 
定义 
是 否 固定 
用 户 
安全 类 型 DEFINER Y 
SQL 数据 访问 NO SQL 
注释 











图 4-1 存储 过 程 编辑 窗口 


(4) 修改 ,删除 存储 过 程 。 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 均 可 修 
改 、 删 除 存 储 过 程 。 


六 、 注 意 事 项 


(1) MySQL 语句 中 出 现 的 数据 库 、 数 据 表 或 字段 名 以 外 的 符号 一 律 以 半角 方式 输 
入 ,如 Create 以 及 引号 ,逗号 、 圆 点 、 括 号 和 分 号 等 ,并 且 英 文字 母 不 区 分 大 小 写 。 

(2) 使 用 MySQL 语句 创建 和 调用 存储 过 程 时 , 按 Fl 键 或 键 可 以 逐个 字符 复制 前 
一 条 执行 过 的 MySQL 语句 , 按 F7 键 可 以 列 出 全 部 执行 过 的 MySQL 语句 供用 户 选择 
执行 。 

(3) 存储 过 程 是 数据 库 中 的 对 象 , 在 创建 存储 过 程 时 需要 先 指 定数 据 库 。 

(4) MySQL 默认 的 语句 结束 符号 是 分 号 ,以 命令 行 方 式 设计 存储 过 程 时 ,为 了 避免 
与 存储 过 程 中 的 SQL 语句 结束 符 冲 突 , 需 要 使 用 Delimiter 改变 存储 过 程 的 结束 符 ,如 
Delimiter # # ,存储 过 程 定义 完毕 后 需要 使 用 Delimiter; 恢 复 默认 的 结束 符 。 

(5) 使 用 Fetch 读 取 数据 前 ,必须 先 声明 并 打开 游标 ,使 用 完毕 ,要 关闭 游标 。 
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七 、 设计 步 又 


1. MySQL 命令 行 方式 创建 存储 过 程 ygxsb_sl 


(1) 登录 MySQL 客户 端 : 打开 XAMPP 控制 面板 , 单 击 shell 按钮 ,在 XAMPP for 
Windows 窗口 中 输入 如 下 命令 登录 MySQL 客户 端 : 


Mysql -uroot -p 


在 提示 信息 enter password: 后 输入 root 用 户 的 密码 后 按 Enter 键 进入 MySQL 客 
户 端 。 
(2) 在 MySQL 命令 行 创建 存储 过 程 : 依次 输入 如 下 语句 : 


Use Wssd; /* 打开 wssd 数 据 库 , 使 之 成 为 当前 数据 库 * / 
Delimiter ## /* 定义 SQL 语句 的 结束 标识 为 ##* / 
Create Procedure ygxsb sl (in hyno varchar (10), out sl int) 
Begin 

Select Sum ( 册 数 ) Into sl From ygxsb Where 会 员 账 号 =hyno And 

Datediff(curdate () ,预购 日 期 )<=30; 

End ## /* 完整 的 存储 过 程 束 标识 为 ## * / 
Delimiter ; /* 恢复 语句 的 结束 标识 为 ; * / 












标 
输入 完 End # 上 # 并 按 Enter 键 后 ,系统 提示 Query OK ,0 row affected(0. 00sec) , 存 
储 过 程 创建 完成 。 
2. MySQL 命令 行 调用 存储 过 程 ygxsb_sl 
在 MySQL 命令 行 调用 存储 过 程 : 依次 输入 如 下 语句 : 


Set @hyno="'2201010001'»; 
Set @sl=0; 


Call ygxsb sl (@hyno,e@s1); 


Select @sl; 


如 图 4-2 所 示 , 输 入 完 最 后 一 行内 容 并 按 Enter 
键 后 ,系统 显示 调用 存储 过 程 的 结果 。 
继续 输入 如 下 语句 ,多 次 调用 存储 过 程 ,查看 


Set @hyno="'1101010001'; 
Call ygxsb sl (@hyno,@s1); 
Select @sl; 

Set @hyno="'2201040002'; 
Call ygxsb sl (@hyno,@s1); 
Select @sl; 








图 4-2 MySQL 命令 行 调 用 存储 过 程 
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3. PHPMyAdmin 主页 创建 存储 过 程 tsb_zl 


(1) 启动 PHPMyAdmin 主页 。 打 开 XAMPP 控制 面板 , 单 击 XAMPP 控制 面板 中 
MySQL 行 中 的 Admin 按钮 ,在 PHPMyAdmin 的 登录 页 面 中 输入 用 户 名 和 密码 , 单 击 
“执行 ”按钮 。 

(2) 在 PHPMyAdmin 主页 添加 程序 。 单 击 wssd 数据 库 名 一 “程序 ”一 “添加 程序 ” 
按钮 ,如 图 4-3 所 示 。 


数据 库 名 “程序 ”选项 卡 
县 结构 加 SQL 忌 搜索 让 查询 性 导出 图 导入 岂 操 作 由 权限 < 浴 程 床 vv 更 多 
程序 加 | 
| 新建 








图 4-3 wssd 数据 库 的 “程序 "选项 卡 


(3) 在 PHPMyAdmin 主页 创建 存储 过 程 。 在 “添加 程序 ”窗口 ,设置 “程序 名 称 ” 为 
tsb_zl、“ 类 型 "为 PROCEDURE ;设置 第 一 个 参数 “方向 ”为 IN,“ 名 字 ” 为 price,“ 类 型 "为 
INT; 单 击 “ 添 加 参数 ”按钮 ,设置 第 二 个 参数 “方向 ”为 OUT,“ 名 字 ” 为 zl,“ 类 型 "为 INT， 
在 “定义 ” 框 中 编写 代码 如 下 : 

Begin 

Select Count (* ) Into zl From tsb Where 定价 <=price; 

End 


如 图 4-1 所 示 , 单 击 该 窗口 中 的 “执行 ”按钮 生成 存储 过 程 。 
4. PHPMyAdmin 主页 调用 存储 过 程 


(1) 调用 存储 过 程 。 在 PHPMyAdmin 主页 中 , 单 击 导 航 面板 中 的 wssd 数据 库 , 选 
择 “ 程 序 ”选项 卡 , 单 击 tsb_l 行 中 的 “执行 ”按钮 。 

(2) 输入 参数 。 进 入 “运行 程序 'tsb_zl” 界 面 , 如 图 4-4 所 示 , 在 price 的 “ 值 ? 列 输入 
50, 单 击 “ 执 行 " 按 钮 ,在 PHPMyAdmin 主页 中 , 即 可 查看 运行 结果 。 

5. PHPMyAdmin 主页 修改 存储 过 程 

(1) 修改 存储 过 程 。 在 PHPMyAdmin 主页 中 , 单 击 导 航 面板 中 的 WSSD 数据 库 , 选 
择 “ 程 序 ” 选 项 卡 , 单 击 tsb_zl 行 中 的 “编辑 ”按钮 。 在 “编辑 程序 ”窗口 , 单 击 “添加 参数 ” 
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名 字 类 型 函数 值 








图 4-4 调用 存储 过 程 输入 参数 


按钮 ,设置 第 三 个 参数 “方向 ”为 IN,“ 名 字 ” 为 min,“ 类 型 "为 INT。 在 “定义” 框 中 修改 代 
码 如 下 : 


Begin 
Select Count (* ) Into zl From tsb Where 定价 <=price And 定价 >=min; 
End 


单 击 该 窗口 中 的 “执行 ”按钮 保存 修改 后 的 存储 过 程 。 

(2) 重新 调用 存储 过 程 。 在 PHPMyAdmin 主页 中 , 单 击 导航 面板 中 的 WSSD 数据 
库 , 选 择 “ 程 序 ” 选 项 卡 , 单 击 tsb_zl 行 中 的 “执行 ”按钮 ,进入 “运行 程序 tsb_zl” 界 面 , price 
的 参数 “ 值 " 输 入 45,min 的 参数 “ 值 ” 输 入 20, 单 击 “ 执 行 ” 按 钮 ,在 PHPMyAdmin 主页 
中 , 即 可 查看 运行 结果 。 


6. PHPMyAdmin 主页 创建 存储 过 程 ygxsb_tj 


(1) 单 击 WSSD 数据 库 名 一 “程序 ”>“ 添 加 程序 ”按钮 。 

(2) 在 PHPMyAdmin 主页 创建 存储 过 程 。 在 “添加 程序 ”窗口 中 设置 “程序 名 称 ” 为 
ygxsb_tj、“ 类 型 "为 PROCEDURE。 设置 第 一 个 参数 “方向 ”为 OUT,“ 名 字 ” 为 cs0,“ 类 
型 "为 INT; 单 击 “ 添 加 参数 ”按钮 ,设置 第 二 个 参数 “方向 ”为 OUT,“ 名 字 ” 为 csl1, “类 型 ” 
为 INT; 第 三 个 参数 “方向 ”为 OUT,“ 名 字 ” 为 cs2,“ 类 型 "为 INT; 第 四 个 参数 “方向 ”为 
OUT,“ 名 字 ” 为 cs3," 类 型 "为 INT; 第 五 个 参数 “方向 ”为 OUT,“ 名 字 ” 为 cs4,“ 类 型 ” 
为 INT。 

(3) 在 “定义 ” 框 中 编写 代码 如 下 : 


Begin 
Declare cs Int; /* 定义 局 部 变量 cs, 其 为 int 类 型 * / 
Declare mqzt Char (1); /* 定义 局 部 变量 mqzt ,其 为 char 类 型 * / 


Declare found Boolean Default True; /* 变量 found, 逻 辑 类 型 ,默认 值 true * / 
Declare cstj Cursor For Select 目前 状态 , 册 数 From ygxsb; /* 定义 游标 cstj * / 
Declare Continue Handler For Not found Set found=False; /* 定义 continue 句 柄 * / 
Set cs0=0,csl=0,cs2=0,cs3=0,cs4=0; /* 变量 置 初 值 * / 

Open cstj; /=* 打开 游标 cstj x*/ 

Fetch cstj Into mqzt,cs /x 获取 游标 中 的 第 一 行 数据 ,保存 在 mqzt 和 cs 变量 中 * / 
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While found Do /* 成 功 获取 游标 中 的 数据 x*/ 
Case mqzt /* 判断 图 书 的 目前 状态 ,将 图 书 数量 累加 到 对 应 的 变量 中 * / 
When "0" Then Set cs0=cs0+cs7 
When "1" Then Set csl=csl+cs; 
When "2" Then Set cs2=cs2+cs; 
When "3" Then Set cs3=cs3+cs; 


When "4" Then Set cs4=cs4+cs7 


End Case; 

Fetch cstj Into mqzt,cs; /* 获取 游标 中 的 下 一 行 数据 * / 
Endwhile; 
Close cstj; /* 关闭 游标 cstj * / 


End 


单 击 该 窗口 中 的 “执行 "按钮 生成 存储 过 程 。 

(4) 调用 存储 过 程 。 在 MySQL 命令 行 客户 端 提示 符 mysql 二 后 依次 输入 如 下 语句 ， 
Use WSSD; /* 打开 WssD 数据 库 使 其 成 为 当前 数据 库 * / 

Set @cs0=0,@csl=0,@cs2=0,@cs3=0,@cs4=0; /* 设置 图 书 各 状态 的 统计 变量 并 清 零 * / 
Call ygxsb tj(@cs0,@csl,@cs2,@cs3,@cs4); /* 调用 存储 过 程 * / 

Select @cs0 as "no send",@csl as "cancelled",@cs2as "in transit", 


@cs3as "signed", @cs4as "refunds"; 


八 、 思 考题 


(1) 使 用 MySQL 语句 和 PHPMyAdmin 可 视 化 工具 两 种 方式 创建 ,管理 和 调用 存储 
过 程 ,各 自 有 哪些 特点 ? 

(2) Delimiter 语句 有 什么 作用 ? 如 果 不 使 用 它 会 有 什么 后 果 ? 

(3) 游标 的 作用 是 什么 ”如 何 声明 .打开 和 关闭 游标 ? 游标 是 否 可 以 脱离 存储 过 程 
独立 使 用 ? 

(4) 存储 过 程 ygxsb_tj 中 的 循环 结构 若 使 用 Repeat 实现 ,应 该 如 何 修改 程序 代码 ? 

(5) 语句 Declare Continue Handler For Not found Set found 王 False 有 何 作 用 ? 是 
否 可 以 省 略 ? 


4.3 存储 函数 设计 


一 、 实验 目 的 


理解 存储 函数 的 作用 :熟练 掌握 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 
种 方式 创建 和 管理 存储 函数 ;能 够 根据 实际 需要 设计 存储 函数 。 
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二 、 实 验 任务 


(1) 在 MySQL 命令 行 创建 存储 函数 JC ,用 于 实现 阶乘 计算 。 

(2) 在 MySQL 命令 行 调用 存储 函数 JC ,分 别 计算 51 和 101。 

(3) 通过 PHPMyAdmin 的 可 视 化 工具 创建 存储 函数 tsb_name, 统 计 tsb 表 中 书 名 
包含 所 给 关键 字 的 图 书 总 册 数 。 

(4) 通过 PHPMyAdmin 的 可 视 化 工具 调用 存储 函数 tsb_name。 

(5) 在 MySQL 命令 行 查看 WSSD 数据 库 中 已 有 的 存储 函数 及 存储 过 程 ;查看 存储 
函数 tsb_name 的 定义 语句 。 

(6) 在 MySQL 命令 行 删除 存储 函数 JC 。 


三 、 任 务 分 析 


设计 存储 函数 ,可 以 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 。 存 
储 函 数 JC 需要 定义 输入 参数 及 函数 返回 值 ,使 用 循环 结构 实现 阶乘 计算 ;存储 函数 tsb_ 
name 的 返回 值 为 满足 条 件 的 记录 数 ,因此 使 用 Return (Select Count(*) From tsb 
Where Locate(name, 书 名 ) ) 语 句 实现 。 


四 、 预 备 知识 


(1) 创建 存储 函数 语句 格式 ，: 


Create Function [< 数据 库 名 > .]< 存 储 函数 名 >( [< 形式 参数 名 1>< 数 据 类 型 1>] [,…]) 
Returns < 函数 返回 值 数据 类 型 > 

[Begin] 
< 语句 序列 > 
Return (< 函数 返回 值 >); 

[End] 


(2) 调用 存储 函数 语句 格式 : 

< 存储 函数 名 >( [< 实际 参数 表 >]) 

(3) 查看 当前 数据 库 中 已 定义 存储 函数 的 语句 格式 : 
Show Function Status; 

(4) 查看 存储 函数 的 定义 语句 格式 : 

Show Create Function [< 数据 名 > .]< 存 储 函 数 名 >; 

(5) 删除 存储 函数 语句 格式 : 

Drop Function [ If Exists ] [< 数据 库 名 > .]< 存 储 函 数 名 > 


(66) 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


五 、 技 能 点 


(1) 创建 存储 函数 。 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 创建 存 
储 函 数 。 

(2) 调用 存储 函数 。 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 调用 存 
储 函 数 。 

(3) 修改 、 删 除 存 储 函 数 。 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 
修改 、 删 除 存 储 函 数 。 


六 、 注 意 事 项 


(1) 存储 函数 是 数据 库 中 的 对 象 , 在 创建 存储 函数 时 需要 先 指 定数 据 库 。 

(2) 通过 MySQL 命令 行 方 式 设计 存储 函数 时 ,必须 先 使 用 Delimiter 语句 改变 存储 
函数 的 结束 符 , 并 在 存储 函数 定义 完毕 后 使 用 Delimiter ; 恢复 默认 的 结束 符 。 

(3) 存储 函数 有 且 仅 有 一 个 返回 值 ,返回 值 必 须 指定 数据 类 型 。 

(4) 存储 函数 可 以 直接 租 入 到 SQL 语句 或 MySQL 表达 式 中 。 

(5) 存储 过 程 可 以 使 用 Select 语句 返回 结果 ,而 存储 函数 不 能 使 用 Select 语句 返回 
结果 。 


七 、 设 计 步 又 


1. MySQL 命令 行 方式 创建 存储 函数 JC 


(1) 登录 MySQL 客户 端 。 打 开 XAMPP 控制 面板 , 单 击 shell 按钮 ,在 XAMPP for 
Windows 窗口 中 输入 如 下 命令 登录 MySQL 客户 端 : 


Mysql -uroot -p 


在 提示 信息 enter password: 后 输入 root 用 户 的 密码 后 按 Enter 键 进入 MySQL 客 
户 端 。 
(2) 在 MySQL 命令 行 创建 存储 函数 。 依 次 输入 如 下 命令 。 


Use WSSD; /* 打开 WssD 数据 库 , 使 之 成 为 当前 数据 库 * / 
Delimiter #4# /* 定义 SgL 语句 的 结束 标识 为 ## x* / 


Create Function JC(n Int) /* 定义 存储 函数 JC * / 
Returns Int 
Begin 

Declare s, int; 

Set i=1,s=18 


Repeat /* 循环 结构 求 n 的 阶乘 * / 
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Set s=sxi; 
Set i=i+1; 
Until i>n 


End repeat; 





Return(s); /x* 返回 计算 结果 * / 
End## /* 存储 过 程 定义 结束 * / 
Delimiter; /* 恢复 MysoL 默认 结束 标识 为 ; * / 


输入 完 End## 按 Enter 键 后 ,系统 提示 Query OK ,0 row affected(0. 00sec) ,存储 函 
数 创建 完成 。 


2. MySQL 命令 行 调用 存储 函数 JC 


在 MySQL 命令 行 调用 存储 函数 ,依次 输入 如 下 命令 。 


Select JC(5); 


Select JC(10); 


系统 显示 调用 存储 函数 的 结果 ,如 图 4-5 所 示 。 


t (0.00 se 


nysql> select jc(10) 


jc (10) 


3628800 


0.00 se 











图 45 调用 存储 函数 JC 


3. PHPMyAdmin 主页 创建 存储 函数 tsb_name 


(1) 启动 PHPMyAdmin 主页 。 打开 XAMPP 控制 面板 , 单 击 XAMPP 控制 面板 中 
MySQL 行 中 的 Admin 按钮 ,在 PHPMyAdmin 的 登录 页 面 中 输入 用 户 名 和 和 密码 , 单 击 
“执行 ”按钮 。 

(2) 在 PHPMyAdmin 主页 添加 程序 。 单 击 WSSD 数据 库 名 一 “程序 ”一 “添加 程 
序 ” 按 钮 。 

(3) 在 PHPMyAdmin 主页 创建 存储 函数 。 在 如 图 4-6 所 示 的 “添加 程序 "窗口 中 
输入 “程序 名 称 ” 为 tsb_name、 选 择 “ 类 型 "为 FUNCTION。 设置 参数 “方向 ”为 name， 
“名 字 ” 为 VYARCHAR.“ 类 型 ”为 20,“ 返 回 类 型 " 设 为 INT。 在 “定义 ” 框 中 编写 代码 
如 下 : 
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”添加 程序 x | 

| 详细 上 
程序 名 称 tsb_name | 
类 型 FUNCTION "| 

A 凶 关于 /从 迁 硕 
pe |name VARCHAR v||20 字符 年 | 辐 市 除 

添加 才 数 
返回 类 型 INT MM 
返回 长 度 / 值 
返回 选项 
1 Begin 
Return(Select Count (+) Fron tsb Where Locate(naae, 书 名 )) 
End 
定义 
是 否 固定 品 
用 户 
安全 类 型 DEFINER ” 
SQL 数据 访问 NO SQL 
注 大 
执行 关闭 
语 
图 4-6 创建 存储 函数 tsb_name 
Begin 


Return (Select Count (* ) From tsb Where Locate (name, 书 名 )); 


/* Locate 函数 用 于 判断 字符 串 包含 关系 * / 
End 


单 击 该 窗口 中 的 “执行 ”按钮 生成 存储 函数 。 

4. PHPMyAdmin 主页 调用 存储 函数 

(1) 调用 存储 函数 。 在 PHPMyAdmin 主页 中 , 单 击 导航 面板 中 的 WSSD 数据 库 , 选 
择 “ 程 序 ” 选 项 卡 , 单 击 tsb_name 行 的 “执行 ”按钮 。 

(2) 输入 参数 查看 结果 。 在 “运行 程序 tsb_name” 界 面 中 ,在 “程序 参数 ” 栏 内 “名 字 ” 
为 name 的 参数 “ 值 ” 处 输入 计算 机 , 单 击 “ 执 行 ” 按 钮 ,在 PHPMyAdmin 主页 中 , 即 可 查 
看 运行 结果 。 


第 4 单元 MySQL 程序 设计 


90 


5. MySQL 命令 行 查看 存储 函数 、 存 储 过 程 


(1) 查看 当前 数据 库 中 的 存储 函数 。 在 MySQL 命令 行 分 别 输入 如 下 语句 并 按 
Enter 键 执行 ,查询 结果 如 图 4-7 所 示 。 


Definer Modified 
Comment | character_set_client 


FUNCTION | root@local 
ut 


FUNCTION | ro 2017-07 





in set (0.01 sec) 


图 4-7 查看 所 有 存储 琐 数 


Use WSSD; 


Show Function Status; /* 查看 当前 数据 库 中 有 哪些 存储 函数 定义 * / 


(2) 查看 当前 数据 库 中 的 存储 过 程 。 在 MySQL 命令 行 输入 如 下 语句 并 按 Enter 键 
执行 。 


Show Procedure Status; “ /* 查看 当前 数据 库 中 有 哪些 存储 过 程 定义 * / 

(3) 查看 存储 函数 定义 语句 。 在 MySQL 命令 行 输入 如 下 语句 并 按 Enter 键 执行 。 
Show Create Function tsb_name; /* 查看 存储 函数 tsb_name 的 定义 语句 * / 

6. MySQL 命令 行 删除 存储 函数 

在 MySQL 命令 行 输入 如 下 语句 并 按 Enter 键 执行 : 


Drop Function If Exists JC; 


八 、 思 考题 


(1) 存储 函数 与 存储 过 程 有 何 异同 ? 是 否 可 以 互相 替换 使 用 ? 
(2) 如 果 存 储 函 数 中 的 Return 语句 返回 一 个 不 同 于 存储 函数 Return 子 句 中 指定 类 
型 的 值 ,会 有 什么 后 果 ? 
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4.4 触发 器 设计 
一 、 实 验 目 的 


理解 触发 器 的 作用 ;熟练 掌握 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 
创建 和 管理 触发 器 ;能 够 根据 实际 需要 设计 触发 器 。 


二 、 实 验 任务 


(1) 在 MySQL 命令 行 创建 触发 器 hyb_delete_backup。 当 删除 hyb 中 的 记录 时 , 通 
过 和 触发 器 自动 将 删除 记录 备份 到 hyb_bak 中 ,同时 在 hyb_bak 中 保存 删除 记录 时 的 日 期 
时 间 。 

(2) 测试 触发 器 hyb_delete_backup。 

(3) 通过 PHPMyAdmin 的 可 视 化 工具 创建 触发 器 yg_insert_before。 当 ygxsb 中 增 
加 记录 时 ,触发 器 自动 更 新 hyb 中 该 会 员 累 计 购 书 金额 .累计 购书 数量 和 最 近 购 书 日 期 3 
个 字段 的 值 。 

(4) 测试 触发 器 yg_insert_before。 

(5) 通过 PHPMyAdmin 的 可 视 化 工具 创建 触发 器 tsb_update_before。 修 改 tsb 中 
记录 时 ,触发 器 自动 判断 若 “ 折 扣 率 ” 低 于 50, 则 不 修改 折扣 率 。 

(6) 测试 触发 器 tsb_update_before。 

(7) 在 MySQL 命令 行 删 除 触 发 器 tsb_update_before。 


三 、 任 务 分 析 


可 以 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 创建 触发 器 。 要 实现 
hyb 的 备份 ,首先 使 用 Create Table 语句 创建 备份 表 hyb_bak ,然后 使 用 Create Trigger 
语句 定义 触发 器 。 设 置 其 触发 事件 为 Delete, 触 发 时 机 为 Before, 操 作 的 表 为 hyb。 使 用 
Delete From 语句 删除 记录 ,使 用 Select 语句 查看 备份 表 中 内 容 的 变化 。 创 建 触发 器 yg_ 
insert_before, 设 置 其 触发 事件 为 Insert, 触 发 时 机 为 Before, 操 作 的 表 为 ygxsb。 触 发 执 
行 语句 Update hyb Set 累计 购书 金额 = 累计 购书 金额 十 New. 册 数 * New. 售 价 , 累计 购 
书 数量 = 累计 购书 数量 十 New. 册 数 ,最 近 购 书 日 期 = Curdate() Where 会 员 账号 一 
New. 会 员 账 号 。 创 建 触发 器 tsb_update_before, 设 置 其 触发 事件 为 Update, 触 发 时 机 为 
Before ,操作 的 表 为 tsb, 触 发 程序 中 使 用 分 支 语句 判断 折扣 率 是 否 小 于 50。 
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四 、 预 备 知 识 


(1) 创建 触发 器 语句 格式 : 
Create Triggle [< 数据 库 > .]< 触 发 器 名 > Before|After < 触发 事件 > 


[Begin] 


On < 表 名 > For Each Row 


< 执行 语句 序列 > 


[End] 


(2) 查看 触发 器 语句 格式 : 


Show Triggers [{ From | in} 数据 库 名 ] 
(3) 删除 触发 器 语句 格式 : 


Drop Trigger [ If Exists ] [< 数据 库 名 > .]< 触 发 器 名 > 


五 、 技 能 点 


(1) 创建 触发 器 。 


(2) 测试 触发 器 。 
(3) 修改 触发 器 。 


(4) 删除 触发 器 。 


六 、 注 意 事项 


使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 创建 触 


操作 表 中 的 数据 ,结合 触发 器 查看 数据 变化 。 
使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 修改 和 触 


使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 删除 触 


(1) 触发 器 是 数据 库 中 的 对 象 ,在 创建 触发 器 时 需要 先 指定 数据 库 。 

(2) 触发 器 基于 表 , 而 不 是 基于 临时 表 和 视图 。 

(3) 触发 程序 中 的 select 语句 不 能 产生 结果 。 

(4) 触发 器 的 触发 时 间 有 Before 和 After, 分 别 表示 在 触发 事件 发 生 之 前 或 之 后 执行 


触发 程序 。 


(5) 触发 程序 中 可 以 使 用 Old 和 New 两 个 关键 字 .Old 关键 字 表 示 修 改 前 或 删除 前 
的 旧 记 录 ,New 关键 字 表 示 修 改 后 或 新 插入 的 新 记录 ,其 中 Old 记录 是 只 读 的 ,可 以 引 


用 ,但 不 可 以 修改 。 
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七 、 设计 步 又 
1. MySQL 命令 行 方式 创建 触发 器 hyb_delete_backup 


(1) 创建 备份 表 文件 。 在 MySQL 命令 行 中 依次 输入 如 下 命令 并 按 Enter 键 执行 。 


Use WSSD; 
Create Table If Not Exists hyb bak like hyb; /* 复制 hyb 表 结 构 * / 
Alter Table hyb bak Add 时 间 Datetime First; 
/* 在 hyb bak 表 中 添加 时 间 字 段 ,类 型 为 datetime, 作 为 表 中 第 一 个 字段 * / 
(2) 创建 触发 器 。 通 过 触发 器 保存 更 新 前 的 数据 ,选择 触发 事件 为 Delete, 触 发 时 机 
为 Before ,操作 的 表 是 hyb ,在 MySQL 命令 行 中 输入 如 下 命令 并 按 Enter 键 执行 。 
Create Trigger wssd.hyb delete backup Before Delete On wssd.hyb 


For Each Row Insert Into hyb bak Select Now(),hyb.* FROM hyb 
Where 会 员 账 号 =old .会 员 账 号 ; 


2. 测试 触发 器 hyb_delete_backup 
(1) 删除 hyb 表 中 记录 。 在 MySQL 命令 行 中 依次 输入 如 下 命令 并 按 Enter 键 执行 。 


Select * From hyb /x* 浏览 hyb 中 的 数据 * / 
Delete From hyb Where Datediff (Curdate() ,最 近 购 书 日 期 )> 365; 
/* 删除 hyb 表 中 最 近 一 年 没有 购书 的 会 员 * / 
(2) 查看 hyb 表 和 hyb_bak 表 中 记录 。 在 MySQL 命令 行 中 依次 输入 如 下 命令 并 按 
Enter 键 执行 。 
Select * From hyb; /* 浏览 删除 记录 后 hyb 表 中 数据 * / 
Select * From hyb bak; /x 浏览 通过 触发 器 备份 的 hbyb bak 表 中 数据 * / 


3. PHPMyAdmin 主页 创建 触发 器 yg_insert_before 


(1) 启动 PHPMyAdmin 主页 。 打开 XAMPP 控制 面板 , 单 击 XAMPP 控制 面板 中 
MySQL 行 中 的 Admin 按钮 ,在 PHPMyAdmin 的 登录 页 面 中 输入 用 户 名 和 密码 , 单 击 
“执行 ”按钮 。 

(2) 在 PHPMyAdmin 主页 添加 触发 器 。 单 击 WSSD 数据 库 名 一 “触发 器 * 一 “添加 
触发 器 "按钮 。 

(3) 在 PHPMyAdmin 主页 创建 触发 器 。 在 “添加 触发 器 ”窗口 ,设置 “触发 器 名 称 ” 
为 yg_insert_before、“ 表 ”为 ygxsb、“ 时 机 ”为 BEFORE 和 “事件 ”为 INSERT, 在 “定义 ” 框 
中 编写 如 下 代码 , 单 击 该 窗口 中 的 “执行 ?按钮 生成 触发 器 。 

Update hyb Set 累计 购书 金额 = 累计 购书 金额 +New. 册 数 * New. 售 价 ， 

累计 购书 数量 = 累计 购书 数量 +New. 册 数 ,最 近 购 书 日 期 =curdate () 
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Where 会 员 账 号 =New .会 员 账 号 ; 


4. 测试 触发 器 yg_insert_before 


(1) 查看 hyb 中 会 员 账 号 为 2201040001 的 记录 。 在 PHPMyAdmin 主页 , 单 击 
WSSD 数据 库 名 一 SQL 选项 卡 ,在 编辑 框 中 输入 如 下 语句 。 


Select 会 员 账 号 ,姓名 ,累计 购书 金额 ,累计 购书 数量 ,最 近 购 书 日 期 From hyb 
where 会 员 账号 = '2201040001'; 


单 击 “ 执 行 ”按钮 ,查询 结果 如 图 4-8 所 示 。 


i27.0.0.1 5 





驻 结 构 眉 SQL “搜索 查询 属 导 出 局 导入 蚁 操作 二 权限 v 更 多 


[0 姓名 累计 购书 金额 累计 购书 数量 最 近 购书 日 期 
WHERE 会 员 账 号 = ,2201040001' 


LIMITO 30 
一 概要 【快速 编辑 ] 【 编 轻 ][ 解释 SQL ]【 种 建 PHP 代码 ][ 刷新 ] 
显示 : 起 始 行 : 0 行 数 : | 30 每 | 100 行 重复 表 头 
+ 选项 
| Fe 了 会 员 账 号 姓名 黑 计 购书 金额 累计 购书 数 ”最近 购 书 日 期 
tn。 但 量 低 到 量 Re 
ko 编 强 丝 复制 加 出 除 2201040001 宁 劲 松 270.0 8| 2016-12-18 


个 ”全 选 / 全 不 选 赴 z 硕 -办 修改 目 员 宁国 导出 








显示 : 起 妈 行 :|0 ”| 行 数 : |30 | 每 | 100 | 行 重 和 
图 4-8 触发 之 前 的 结果 

(2) 在 ygxsb 中 插入 记录 。 在 PHPMyAdmin 主页 , 单 击 WSSD 数据 库 名 一 SQL 选 
项 卡 ,在 编辑 框 中 输入 如 下 语句 , 单 击 “ 执 行 " 按 钮 。 

Insert into ygxsb values (17," 978-7-115-41056- 6",1,curdate(),50,45, 

'2201040001',0,'0'); 

(3) 再 次 查看 hyb 中 会 员 账号 为 2201040001 的 记录 。 在 PHPMyAdmin 主页 , 单 击 

WSSD 数据 库 名 一 SQL 选项 卡 ,在 编辑 框 中 输入 如 下 语句 。 


Select 会 员 账号 ,姓名 ,累计 购书 金额 ,累计 购书 数量 ,最 近 购 书 日 期 From hyb 
where 会 员 账号 = '2201040001'; 





单 击 “ 执 行 ”按钮 ,查询 结果 如 图 4-9 所 示 。 
5. PHPMyAdmin 主页 创建 触发 器 tsb_update_before 


(1) 启动 PHPMyAdmin 主页 。 打开 XAMPP 控制 面板 , 单 击 XAMPP 控制 面板 中 
MySQL 行 中 的 Admin 按钮 ,在 PHPMyAdmin 的 登录 页 面 中 输入 用 户 名 和 密码 , 单 击 
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驻 结 构 司 SQL * 搜 索 查询 层 叶 出 局 导入 四 操作 = 权限 v 更 多 


商人 姓名 累计 购书 金额 累计 购书 数量 最 近 购书 日 期 
WHERE 会 员 账 号 ="2201040001" 


LMITO 30 
一 概要 【 快 束 蝙 轿 ] [ 编 经 ][ 解释 SQL ] [ 创建 PHP 代码 ] [ 吊 新 ] 
显示 : 起 折 行 : 0 行 数 : | 30 每 10 行 重复 表 头 
| 选项 
4 下 ~ 了 会 员 账号 ”姓名 累计 购书 金额 累计 购书 数量 最 近 购书 日 期 
每 千 元 增加 1% 拆 扣 ,但 景 低 到 用 于 清理 过 期 会 员 
Bok 
忆 编导 对 复制 合 删除 2201040001 宁 劲 松 2520.0 58 2017-07-14 


个 全 迁 / 全 不 选 进 中 胡 。 帮 修 改 目 吗 人 思 叶 出 
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图 4-9 触发 之 后 的 结果 
“执行 ?按钮 。 
(2) 在 PHPMyAdmin 主页 添加 触发 器 。 单 击 WSSD 数据 库 名 一 “触发 器 "一 “添加 
触发 器 "按钮 。 
(3) 在 PHPMyAdmin 主页 创建 触发 器 。 在 “添加 触发 器 "窗口 ,设置 "触发 器 名 称 ” 
为 tsb_update_before“ 表 ?为 tsb“ 时 机 ”为 BEFORE 和 "事件 ”为 UPDATE, 在 “定义 ” 框 
中 编写 如 下 代码 。 


If New. 折 扣 率 < 50 Then 
Set New. 折 扣 率 =01d. 折 扣 率 ; 
End If 


单 击 该 窗口 中 的 “执行 ”按钮 生成 触发 器 。 
6. 测试 触发 器 tsb_update_before 


(1) 查看 tsb 表 中 书号 为 978-7-115-40907-2 的 记录 。 在 PHPMyAdmin 主页 , 单 击 
WSSD 数据 库 名 一 SQL 选项 卡 ,在 编辑 框 中 输入 如 下 语句 。 


Select * Fromtsb where 书号 ='978-7-115-40907-2'; 


单 击 “ 执 行 "按钮 ,查询 结果 如 图 4-10 所 示 。 
(2) 修改 记录 并 测试 。 在 PHPMyAdmin 主页 , 单 击 WSSD 数据 库 名 一 SQL 选项 
卡 ,在 编辑 框 中 输入 如 下 语句 , 单 击 “执行 "按钮 。 


Update tsb set 折扣 率 =80 where 书号 ='978-7-115- 40907-2'; 
单 击 SQL 选项 卡 ,在 编辑 框 中 输入 如 下 语句 。 
Select * Fromtsb where 书号 ='978-7-115-40907-2'; 
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图 4-10 触发 之 前 的 结果 


单 击 “ 执 行 "按钮 ,查询 结果 如 图 4-11 所 示 。 
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(3) 修改 记录 并 测试 。 在 PHPMyAdmin 主页 , 单 击 WSSD 数据 库 名 一 SQL 选项 
卡 , 在 编辑 框 中 输入 如 下 语句 , 单 击 “执行 "按钮 。 


Update tsb set 折扣 率 =30 where 书号 = '978-7-115- 40907-2'; 
单 击 SQL 选项 卡 , 在 编辑 框 中 输入 如 下 语句 。 

Select * Fromtsb where 书号 ='978-7-115-40907-2'; 

单 击 “ 执 行 "按钮 ,查询 结果 如 图 4-12 所 示 。 

7. PHPMyAdmin 主页 查看 触发 器 tsb_update_before 


在 PHPMyAdmin 主页 , 单 击 WSSD 数据 库 名 一 “触发 器 ”选项 卡 , 单 击 tsb_update_ 
before 行 中 的 “编辑 ”按钮 ,进入 “编辑 触发 器 "界面 , 若 修 改 了 触发 器 的 内 容 , 单 击 “ 执 行 ” 
按钮 即 可 保存 修改 结果 。 
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图 4-12 触发 之 后 的 结果 


8. MySQL 命令 行 删除 触发 器 tsb_update_before 
在 MySQL 命令 行 输入 如 下 语句 并 按 Enter 键 执行 。 


Drop Trigger If Exists tsb update before; 


八 、 思 考题 


(1) 触发 器 可 以 实现 哪些 功能 ? 
(2) 触发 器 的 触发 事件 有 几 种 ? 触发 时 间 有 几 种 ? 
(3) 一 个 数据 库 表 最 多 可 以 设置 几 种 类 型 的 触发 器 ? 


4.5 事件 设计 


一 、 实验 目 的 


理解 事件 的 作用 ;掌握 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 创 
建 事件 ;能 够 根据 实际 需要 设计 事件 。 


二 、 实验 任 务 


(1) 开启 事件 调度 器 。 

(2) 在 MySQL 命令 行 创建 事件 ygxsb_tjbk, 用 于 实现 从 当前 时 间 算 起 ,每 间隔 30 
秒 调用 一 次 存储 过 程 ygxsb_tj, 将 结果 及 调用 时 间 存 储 到 ygxstjb 表 中 ,直到 2020 年 12 
月 31 日 截止 。 

(3) 通过 PHPMyAdmin 的 可 视 化 工具 创建 事件 ygxsb_delete, 用 于 实现 从 当前 时 
间 算 起 ,每 间隔 一 天 清空 ygxstjb 表 记 录 ,直到 2020 年 12 月 31 日 截止 。 

(4) 在 MySQL 命令 行 修改 事件 ygxsb_delete 的 间隔 时 间 为 1 个 星期 。 

(5) 在 MySQL 命令 行 关闭 事件 ygxsb_tjbk。 
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(6) 在 MySQL 命令 行 删除 事件 ygxsb_tjbk。 
三 、 任 务 分 析 


在 创建 事件 前 需要 开启 事件 调度 器 , 创建 事件 可 以 使 用 MySQL 命令 和 
PHPMyAdmin 可 视 化 工具 两 种 方式 。 事件 ygxsb_tjbk 的 时 间 间 隔 为 30 秒 , 起 始 时 间 为 
当前 时 间 ,终止 时 间 为 2020 年 12 月 31 日 ,事件 内 容 为 调用 存储 过 程 gxsb_b ,并 将 统计 
结果 及 调用 时 间 存 储 到 ygxstjb 表 中 ,然后 使 用 Call 语句 调用 存储 过 程 和 Insert 语句 插 
入 表 记 录 。 事 件 ygxsb_delete 的 时 间 间 隔 为 1 天 ,起 始 时 间 为 当前 时 间 , 终 止 时 间 为 
2020 年 12 月 31 日 ,事件 内 容 为 使 用 Delete 语句 清空 ygxstjib 表 记 录 。 


四 、 预 备 知识 


(1) 查看 事件 调度 器 设置 情况 的 语句 格式 : 
Show Variables Like 'Event_ Scheduler'; 
(2) 开启 事件 功能 语句 格式 : 

Set Global Event_ Scheduler=1; 

(3) 创建 事件 语句 格式 : 


Create Event [If Not Exists] < 事件 名 > on Schedule At < 时 间 > [+Interval < 时 间 间 隔 > 
] 1 Every < 时 间 间 隔 > [Starts < 开始 时 间 > [+Interval < 时 间 间 隔 >]] 

[Ends < 结束 时 间 > [+Interval < 时 间 间 隔 >]] 

Do < 执行 语句 序列 > 

(4) 修改 事件 语句 格式 : 

Alter Event < 事件 名 > [Rename To < 新 事件 名 >] [On Schedule At < 时 间 > [+Interval < 时 间 
间隔 >] IEvery < 时 间 间 隔 > [Starts < 开始 时 间 > [+ Interval < 时 间 间 隔 >]] [Ends < 结束 时 
间 > [+ Interval < 时 间 间 隔 >]]] [Enable | Disable] 

[Do < 执行 语句 序列 > ] 


(5) 删除 事件 语句 格式 : 


Drop Event [If Exists] < 事件 名 > 


五 、 技 能 点 


(1) 创建 事件 。 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方式 创建 事件 。 
(2) 修改 、 关 闭 、 删 除 事件 。 使 用 MySQL 命令 和 PHPMyAdmin 可 视 化 工具 两 种 方 
式 修 改 、 关 闭 .删除 事件 。 
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六 、 注 意 事项 


(1) 事件 是 数据 库 中 的 对 象 ,在 创建 事件 时 需要 先 指定 数据 库 。 

(2) 在 MySQL 中 事件 调度 器 默认 为 关闭 状态 ,开启 事件 调度 器 才能 让 事件 发 生 
作用 。 

(3) 通过 MySQL 命令 行 方式 设计 事件 时 ,需要 使 用 Delimiter 语句 改变 结束 符 , 并 
在 事件 定义 完毕 后 使 用 Delimiter; 恢复 默认 的 结束 符 。 

(4) 车 要 停止 事件 ,可 以 关闭 事件 而 不 是 删除 事件 。 


七 、 设 计 步 又 


1. 开启 事件 调度 器 


(1) 登录 MySQL 客户 端 。 打 开 XAMPP 控制 面板 , 单 击 shell 按钮 ,在 XAMPP for 
Windows 窗口 中 输入 如 下 命令 并 按 Enter 键 执 行 : 

Mysql -uroot -p 

在 提示 信息 enter password: 后 输入 root 用 户 的 密码 按 Enter 键 进入 MySQL 客 
户 端 。 

(2) 查看 Event_Scheduler 的 设置 情况 。 在 MySQL 命令 行 输入 如 下 命令 并 按 Enter 
键 执行 。 

Show Variables Like 'Event Scheduler'; 

车 Event_Scheduler 参数 的 值 显示 为 On, 表 示 Event_Scheduler 已 开启 , 则 不 需要 继 
续 进 行 设置 ;和 否则 继续 执行 步骤 (3) 。 

(3) 开启 Event_Scheduler。 在 MySQL 命令 行 依次 输入 如 下 命令 并 按 Enter 键 
执行 。 

Set Global Event_Scheduler=1; /* 开启 Event_Scheduler, 使 事件 调度 器 处 于 工作 状态 * / 

Show Variables Like 'Event_Scheduler'; /* 再 次 查看 Event_Scheduler 设置 * / 


2. MySQL 命令 行 创建 事件 
(1) 新 建 ygxstjb 表 。 在 MySQL 命令 行 分 别 输入 如 下 语句 并 按 Enter 键 执行 。 


Use WSSD; 
Create Table ygxstjb(tjdate timestamp,nosend int (8) ,cancelled int (8), 
intransit int (8) ,signed int (8),refunds int (8)); /* 新 建 ygxstjb 表 * / 
(2) MySQL 命令 行 方式 创建 事件 ypxsb_tjbk。 在 MySQL 命令 行 分 别 输入 如 下 语 
句 并 按 Enter 键 执行 。 


第 4 单元 MySQL 程序 设计 


Delimiter $$ 
Create Event If Not Exists ypxsb tjbk 
On Schedule Every 30 Second 
Starts Curdate() Ends '2020-12-31" 
Do 
Begin 
Set @cs0=0,@csl=0,@cs2=0,@cs3=0,@cs4=0; 
Call ygxsb tj(@cs0,@csl,@cs2,@cs3,@cs4); 
Insert into ygxstjb (nosend,cancelled, intransit, signed, refunds) 
values (@cs0,@csl,@cs2, @cs3,@cs4); 
End $$ 
Delimiter; /* 恢复 结束 标识 为 ; * / 


(3) 浏览 ygxstjb 表 。 在 MySQL 命令 行 输入 如 下 语句 并 按 Enter 键 执行 。 


Select * From ygxstjb; 


3. PHPMyAdmin 主页 创建 事件 


(1) 启动 PHPMyAdmin 主页 。 打 开 XAMPP 控制 面板 , 单 击 XAMPP 控制 面板 中 
MySQL 行 中 的 Admin 按钮 ,在 PHPMyAdmin 的 登录 页 面 中 输入 用 户 名 和 密码 , 单 击 
“执行 ”按钮 。 

(2) 在 PHPMyAdmin 主页 添加 事件 。 单 击 WSSD 数据 库 名 一 “事件 ”一 “添加 事件 ” 
按钮 。 

(3) 在 PHPMyAdmin 主页 创建 事件 。 在 “添加 事件 "窗口 中 输入 “事件 名 称 ” 为 
ypxsb_delete、 选 择 “ 状 态 ” 为 ENABLED “事件 类 型 "为 RECURRING “运行 周期 "为 1 
DAY “起 始 时 间 ” 为 “2017-07-19 00:00:00” 及 “终止 时 间 ” 为 “2020-12-31 23:59:59”, 在 
“定义 ” 框 中 输入 如 下 代码 ,最 后 单 击 “ 执 行 ” 按 钮 。 


Delete From ygxstjb; 

4. MySQL 命令 行 修改 事件 

输入 如 下 语句 并 按 Enter 键 执行 。 

Alter Event ypxsb delete ON Schedule Every 1 Week; 

5. MySQL 命令 行 关闭 事件 

在 MySQL 命令 行 输入 如 下 语句 并 按 Enter 键 执行 。 
Alter Event ypxsb tjbk On Completion Preserve Disable; 
6. MySQL 命令 行 删除 事件 

在 MySQL 命令 行 输入 如 下 语句 并 按 Enter 键 执行 。 
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Drop Event If Exists ypxsb tjbk; 


八 、 思 考题 


(1) 什么 是 事件 ? 其 功能 是 什么 ? 
(2) 如 何 开启 事件 调度 器 ? 


(3) 有 几 种 办 法 停止 事件 调度 器 ? 关闭 与 删除 事件 有 何不 同 ? 


第 4 单元 “MysQL 程序 设计 (0 


静态 网 页 设计 主要 使 用 HTML 语言 和 CSS 技术 实现 。 通 过 Dreamweaver 可 以 建 
立 站 点 ,生成 静态 网 页 ,完成 模板 .登录 ,密码 修改 .显示 数据 .新 增 数 据 、 修 改 数据 和 删除 
数据 等 网 页 设计 。 





5.1 建立 网 上 书店 站 点 


一 、 实 验 目 的 


通过 Dreamweaver 的 “站 点 设置 "窗口 新 建站 点 ,使 用 文件 面板 管理 和 同步 文件 , 掌 
握 建 立 和 管理 站 点 的 基本 过 程 和 方法 。 


二 、 实验 任 务 


(1) 在 DD 盘 新 建 wssd 文件 夹 ,作为 网 上 书店 的 本 地 站 点 根 目录 。 
(2) 在 xampp\htdocs 目录 中 新 建 wssd 文件 夹 , 作 为 网 上 书店 的 服务 器 根 目录 。 


(3) 用 Dreamweaver 的 “站 点 设置 "窗口 新 建站 点 。 
(4) 新 建站 点 子 目 录 , 同 步 本 地 和 服务 器 文件 夹 的 内 容 。 
三 、 任务 分 析 


任务 (1) 是 建立 wssd 站 点 的 本 地 站 点 文件 夹 ,任务 (2) 是 建立 wssd 站 点 的 服务 器 文 
件 夹 。 在 开发 网 站 时 ,本 地 站 点 文件 夹 和 服务 器 文件 夹 可 以 创建 在 同一 台 计 算 机 中 。 通 


过 Dreamweaver 的 “站 点 设置 "窗口 可 以 新 建站 点 ,使 用 文件 面板 可 以 完成 本 地 文件 和 服 
务 器 文件 的 管理 和 同步 。 


四 、 预 备 知识 


(1) Dreamweaver 界面 。 是 菜单 面板 、 工 具 箱 和 文档 窗口 的 组 合 视图 。 为 适应 不 同 


用 户 的 操作 习惯 ,系统 预定 义 了 设计 器 、 应 用 程序 开发 人 员 和 编码 人 员 等 多 种 工作 区 视 
图 ;用 户 也 可 自 定义 和 保存 工作 区 视图 。 用 “窗口 "菜单 或 窗口 右上 角 “ 工 作 区 视图 ” 选 框 ， 
可 以 切换 工作 区 视图 ; 单 击 “ 重 置 ”选项 可 以 恢复 默认 工作 区 视图 。“ 应 用 程序 开发 人 员 
(高 级 )" 工 作 区 视图 如 图 5-1 所 示 。 
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图 5-1 应 用 程序 开发 人 员 ( 高 级 ) 工 作 区 视图 


(2)“ 文 件 ” 面 板 。 使 用 “文件 ”面板 (如 图 5-2 所 示 ) 可 以 查看 和 管理 站 点 中 的 文件 ， 
也 可 以 进行 本 地 和 远程 服务 器 之 间 文 件 的 传输 。 单 击 “ 连 接 "按钮 可 控制 本 地 站 点 和 远程 
站 点 之 间 的 连接 或 断 开 ; 单 击 “ 下 载 ? 按 钮 可 以 将 文件 从 远程 站 点 复制 到 本 地 站 点 ; 单 击 
“上 传 ”按钮 可 以 将 文件 从 本 地 站 点 复制 到 远程 站 点 ; 单 击 “ 视 图 "下拉 按 钮 ,可 以 在 本 地 视 
图 、 远 程 服务 器 、 测 试 服务 器 和 存储 库 视 图 之 间 进 行 切换 ,查看 和 管理 位 于 不 同位 置 的 
文件 。 


























图 5-2 “文件 ”面板 
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五 、 技 能 点 


(1) 新 建站 点 。 站 点 是 开发 及 建设 网 站 的 环境 ,用 于 存储 网 站 开发 阶段 的 文件 夹 ( 目 
录 ) 及 其 相关 资源 文件 。 站 点 包含 开发 网 站 计算 机 中 的 本 地 文件 夹 和 发 布 网 站 资源 的 服 
务 器 文件 来。 用 “管理 站 点 ”功能 可 以 新 建 和 管理 站 点 。 

(2) 管理 和 同步 文件 。 用 “文件 ”面板 可 以 方便 地 对 本 地 站 点 文件 夹 和 服务 器 文件 夹 
进行 管理 和 同步 。 


六 、 注 意 事 项 


(1) 启动 Dreamweaver 后 ,要 选择 对 应 的 工作 区 视图 。 
(2) 使 用 “站 点 设置 "窗口 新 建站 点 前 , 先 启动 Apache Web 服务 。 


七 、 设 计 步 又 


1. 新 建站 点 根 目 录 


(1) 新 建 本 地 站 点 根 目 录 。 双 击 桌面 “ 计 算 机 ”图标 ,在 D 盘 下 新 建 wssd 文件 夹 。 
(2) 新 建 服务 器 站 点 根 目 录 。 进 入 xampp 安装 目录 下 的 htdocs 文件 夹 ,如 DD; 
\xampp\htdocs, 新 建文 件 夹 wssd。 


2. 新 建 Dreamweaver 站 点 


(1) 启动 Apache 和 MySQL。 双 击 桌 面 “XAMPP-Control" 图 标 , 分 别 单 击 Apache 
和 MySQL 的 Start 按钮 。 

(2) 启动 Dreamweaver。 双 击 桌面 Dreamweaver 图 标 。 单 击 * 窗 口 ” 菜 单一 “工作 区 
布局 选 框 ” 一 "应 用 程序 开发 人 员 ( 高 级 ) "选项 。 

(3) 新 建站 点 。 单 击 “ 站 点 ”>“ 新 建站 点 ”菜单 项 ,在 “站 点 设置 "窗口 中 ,输入 “站 点 
名 称 ” 为 wssd,“ 本 地 站 点 文件 夹 ” 为 D:\wssd\。 

(4) 设置 服务 器 。 单 击 “ 站 点 设置 "窗口 的 “服务 器 "一 “十 ”按钮 ,设置 结果 如 图 5-3 
所 示 。 单 击 “ 保 存 " 按 钮 ,选中 “测试 " 复 选 框 ,再 单 击 “ 保 存 ” 按 钮 。 


慑 58S 和 [ES ] 
连接 法 : [于 地 届 线 ee 
服务 器 文件 夹 : [D: Wampphtdocs wssd\ ES] 
Web URL: | http://ocahost/wssd/ 


























图 5-3 服务 器 设置 窗口 
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3. 上 传 站 点 文件 


(1) 新 建 子 目录 。 布 击 “ 文 件 ” 面 板 的 “站 点 -wssd” 图 标 , 选 择 “ 新 建文 件 夹 ”选项 , 输 
入 文件 夹 名 为 css。 用 相同 方法 创建 文件 夹 images, 如 图 5-4 所 示 。 

(2) 复制 资源 文件 。 网 站 使 用 的 样式 表 文 件 、 图 片 .声音 和 视频 等 称 为 网 站 的 资源 文 
件 。 资 源 文件 通常 在 网 站 制作 前 设计 完成 。 网 上 书店 网 站 的 资源 文件 有 样式 表 文 件 
wssd. css( 样 式 代 码 参 见 附 录 A) 和 网 站 LOGO 图 片 logo. jpg。 

通过 Windows 资源 管理 器 将 文件 wssd. css 复制 到 D:\wssdNcss 文件 夹 中 ,将 文件 
logo. jpg 复制 到 D:\wssd\images 文件 夹 中 。 

(3) 上 传 站 点 文件 。 选 中 “站 点 -wssd(D:\wssd)”, 单 击 “ 文 件 ” 面 板 中 上 传 按 钮 ,将 
本 地 站 点 文件 夹 中 的 文件 上 传 到 服务 器 文件 夹 中 。 单 击 “ 视 图 ”按钮 ,选择 “测试 服务 器 ” 
选项 ,查看 服务 器 上 的 文件 ,如 图 5-5 所 示 。 





[汉江 服务 
日 大 D:\xmpp\htdocs\vssd\ 
日 电 ess 
加 vssd ess 


| 本 地 文件 
日 口 Mv 0 wd) 
BD ee Binges 
国 leo jpe 
和 incluas 


田 - 回 inages 
田 - 恩 include 
1 





图 5-4 本 地 站 点 目录 结构 图 5-5 服务 器 站 点 目录 结构 


八 、 思 考题 

(1) 如 何 建立 远程 测试 服务 器 ? 

(2) 如 何 同步 本 地 文件 和 服务 器 文件 ? 

(3) 什么 时 候 需 要 将 服务 器 文件 下 载 到 本 地 ? 

(4) 对 远程 文件 夹 的 位 置 有 何 要 求 ? 仅 调试 HTML 文件 是 否 需要 配置 服务 器 ? 不 
配置 服务 器 或 服务 器 配置 不 正确 ,对 调试 PHP 程序 有 何 影响 ? 


5.2 网 页 模板 设计 和 浏览 


一 、 实 验 目的 


设计 网 页 模板 并 在 局 域 网 环境 中 浏览 所 设计 的 网 页 模板 ,掌握 静态 网 页 设计 的 基本 
方法 和 请 求 局 域 网 Web 站 点 服务 的 基本 过 程 。 


二 、 实验 任务 
(1) 设计 如 图 5-6 所 示 的 网 页 模板 muban. html。 
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图 5-6 网 页 模板 


(2) 查看 计算 机 的 IP 地 址 。 
(3) 在 局 域 网 中 ,通过 IP 地 址 访问 其 他 计算 机 上 的 网 站 。 


三 、 任务 分 析 
任务 (1) 在 Dreamweaver 的 代码 文档 窗口 中 设计 网 页 ,需要 使 用 已 经 制作 的 图 像 和 


CSS 文件 。 任 务 (2) 和 任务 (3) 使 用 Windows 命令 查看 IP 地 址 并 访问 局 域 网 中 其 他 计算 
机 网 站 。 


四 、 预 备 知识 
(1) 模板 。 是 一 种 快速 设计 相同 风格 网 页 的 样式 。 设 计 网 页 模板 与 普通 网 页 步骤 相 


同 ,在 模板 网 页 中 只 需要 把 页 头 和 页 脚 等 网 页 共有 元 素 设计 出 来 。 
(2) IPConfig 命令 。 用 于 显示 本 机 TCP/IP 协议 配置 的 信息 ,查看 本 机 IP 地 址 。 


五 、 技 能 点 

(1) 创建 模板 网 页 。 将 网 页 中 页 头 和 页 脚 等 位 置 的 固定 信息 加 入 到 网 页 模板 中 ，, 简 
化 其 他 风格 类 似 网 页 的 开发 。 

(2) 调试 站 点 。 浏 览 器 地 址 栏 输入 IP 地 址 ,访问 其 他 计算 机 上 的 网 站 资源 。 
六 、 注 意 事项 


(1) 引用 CSS 文件 位 置 要 正确 。 
(2) 网 页 文件 要 保存 在 当前 站 点 的 文件 夹 中 ,不 要 随便 改变 文件 的 存储 位 置 。 
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七 、 设计 步 又 
1. 模板 网 页 设计 


(1) 新 建 网 页 。 单 击 “ 文 件 ”" 菜 单一 “新 建 ” 选 项 ,选择 “页 面 类 型 "为 HTML,“ 布 局 ” 
为 “无 ,文档 类 型 ?为 HTML5, 单 击 “ 创 建 "按钮 。 

(2) 修改 二 head 二 元 素 。 用 过 title 二 标签 设置 网 页 标题 ,二 link 放 标签 关联 css 文件 ， 
二 meta 二 标签 声明 文档 编码 ,在 “代码 "视图 下 ,修改 二 head 二 标签 中 的 内 容 , 代 码 如 下 : 


<head><title> 网 上 书店 < /title> 
<link rel="stylesheet" type="text/css" href="css/wssd.css"> 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8"></head> 
(3) 设计 网 页 背景 。 修 改 二 body 二 标签 ,设置 class 属性 ,代码 如 下 : 
<body class="bg"> 


(4) 页 头 设计 。 显 示 导 航 链接 等 信息 ,在 二 body class 一 "bg "之 标签 后 按 Enter 键 ， 
插入 如 下 代码 : 


<div id="header"> 
<div class="header-t1"><a href="index.html"> 首 页 </a></div> 
<div class="header-t23">2017-04-06</div> 
<div class="header-t23">Thursday</div> 
<div class="header-t23"> 请 登录 < /div></div> 


(5) 网 页 LOGO 设计 。LOGO 用 图 片 文件 表示 ,在 页 头 设计 代码 后 按 Enter 键 , 插 
入 如 下 代码 : 


<div class="wrap"> 
<div class="1logo">< imgsrc="images/logo.jpg" width="900" height="300"> 
</div> 


</div> 


(6) 操作 区 域 设计 。 显 示 具 体操 作 内 容 , 在 网 页 LOGO 设计 代码 后 按 Enter 键 ,插入 
如 下 代码 : 


<div class="wrap"> 
<div class="area"> 
<div class="areatitle"> 标 题 </div> 


<div class="areamain"> 内 容 </div></div></div> 


(7) 页 脚 设计 。 显 示 网 页 版 权 等 信息 ,操作 区 域 设计 代码 后 按 Enter 键 ,插入 如 下 
代码 : 


<div class="footer"> 
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<p> 吉 林 大 学 公共 计算 机 教学 与 研究 中 心 < /p> 
<p>2017 年 制作 </p>< /div> 


(8) 预览 。 按 F12 键 ,在 “另存 为 ”对话 框 中 ,输入 文件 名 为 muban. html, 单 击 “ 保 存 ” 
按钮 ,浏览 效果 如 图 5-6 所 示 。 
2. 获取 本 机 IP 地 址 


(1) 启动 控制 台 。 按 [WIN]+R 键 ,在 “打开 ” 框 输入 cmd, 单 击 “ 确 定 " 按 钮 。 
(2) 获取 IP。 在 控制 台 窗 口 输入 ipconfig /all 并 按 Enter 键 ,本 机 IP 如 图 5-7 所 示 。 














图 5-7 查看 全 窗口 


3. 通过 局 域 网 访问 站 点 


在 局 域 网 内 其 他 计算 机 的 浏览 器 地 址 栏 输入 http://192. 168. 1. 104/wssd/muban. 
html, 访 问 网 上 书店 的 网 页 模板 。 


八 、 思 考题 


(1) 如 何 将 站 点 发 布 到 互联 网 ? 
(2) 如 何 申请 站 点 域名 ?如 何 将 站 点 域名 和 服务 器 IP 地 址 进行 绑 定 ? 





5.3 登录 网 页 和 密码 修改 网 页 设计 
一 、 实 验 目 的 
通过 设计 登录 和 密码 修改 网 页 ,掌握 包含 表单 元 素 的 静态 网 页 设计 方法 。 


二 、 实 验 任务 





(1) 在 网 页 模板 基础 上 设计 如 图 5-8 所 示 的 登录 网 页 index. html。 
(2) 在 网 页 模板 基础 上 设计 如 图 5-9 所 示 的 密码 修改 网 页 xgmm. html。 
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网 注 焊 店 网 站 示例 


0 








图 5-8 登录 网 页 


网 此 简 店 网 站 示 创 


0 


请 圈 入 |B 宅 码 
请 给 入 新 安 玛 
再 坟 入 新 要 码 











图 5-9 密码 修改 网 页 


三 、 任 务 分 析 

两 个 任务 要 求 相 似 , 都 是 以 网 页 模板 为 基础 设计 网 页 。 任 务 (1) 在 代码 窗口 中 编写 代 
码 创 建 表单 ,任务 (2) 在 设计 窗口 中 通过 可 视 化 操作 创建 表单 ,任务 (2) 的 设计 方法 更 便 
捷 , 但 是 某 些 网 页 效果 无 法 通过 可 视 化 操作 实现 。 


四 、 技 能 点 


设计 表单 。 在 设计 窗口 中 使 用 “插入 "菜单 的 “表单 ”项 ,或 在 代码 窗口 中 编写 代码 都 
可 以 完成 表单 设计 。 
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五 、 设 计 步 又 
1. 用 户 登 录 网 页 设计 


(1) 新 建 网 页 。 启 动 Dreamweaver, 布 击 “ 文 件 ” 面 板 中 的 muban. html, 选 择 “ 编 辑 ” 
一 “复制 "选项 。 布 击 “*muban - 拷贝 . html" 文 件 , 选 择 “ 编 辑 ”>“ 重 命名 ”选项 ,输入 index 
后 按 Enter 键 ,在 “代码 "视图 下 编辑 index. html 中 的 内 容 。 

(2) 设计 登录 表单 。 将 “标题 "两 字 改 为 “用 户 登 录 ”, “内容” 两 字 替 换 成 如 下 代码 段 : 


<form action="./indexlogin.php" method="post"> 

<div class="login"> 

账号 :<input type="text" name="userid"/><br> 

<!--hyb 表 中 的 会 员 账 号 ,用 于 验证 用 户 身份 --> 

密码 : <input type="password" name="password"/><br> 

<!--hyb 表 中 的 密码 --> 

<p><input name="sub" type="submit" value=" 登 录 "/></p> 
</form></div> 


(3) 预览 。 按 F12 键 浏览 网 页 (如 图 5-8)。 
2. 修改 密码 的 网 页 设计 


(1) 布 击 “ 文 件 ” 面 板 中 的 muban. html, 选 择 “ 编 辑 ” 一 “复制 ”选项 。 布 击 “muban - 
拷贝 .html”* 文 件 , 选 择 “ 编 辑 ” 一 “ 重 命名 ”选项 ,输入 xgmm 后 按 Enter 键 ,在 “设计 ”视图 
中 编辑 xgmm. html 中 内 容 。 

(2) 将 文字 “标题 "替换 为 “修改 密码 ”; 删 除 “ 内 容 ” 两 个 字 , 在 “属性 ”面板 中 “类 ”选择 
areatable; 单 击 “ 插 入 ”菜单 一 “表单 >“ 表单" 选项 。 

(3) 单 击 “ 插 入 ”菜单 一 “表单 ”一 “文本 域 ”选项 ,在 “输入 标签 辅助 功能 属性 ”对 话 框 
中 ,设置 ID 值 为 oldpwd,“ 标 签 " 值 为 “请 输入 旧 密 码 ”, 单 击 “ 确 定 ” 按 钮 。 

(4) 在 新 文本 域 右 侧 按 Enter 键 , 单 击 “ 插 入 "菜单 一 “表单 ”一 “文本 域 "选项 ,在 “ 输 
人 标签 辅助 功能 属性 ?对 话 框 中 ,设置 ID 值 为 newpwd1,“ 标 签 " 值 为 “请 输入 新 密码 ”, 单 
击 “ 确 定 ” 按 钮 。 

(5) 在 新 文本 域 右 侧 按 Enter 键 , 单 击 “ 插 入 "菜单 一 “表单 ”一 “文本 域 " 选 项 ,在 “ 输 
和 人 标签 辅助 功能 属性 ”对 话 框 中 ,设置 ID 值 为 newpwd2,“ 标 签 ” 值 为 “ 青 输入 新 密码 ”, 单 
击 “ 确 定 ” 按 钮 。 

(6) 在 新 文本 域 右 侧 按 Enter 键 , 单 击 “ 插 入 "菜单 一 “表单 >“ 按钮 ”选项 ,在 “输入 
标签 辅助 功能 属性 ”对 话 框 中 ,设置 ID 值 为 sub, 单 击 “ 确 定 ” 按 钮 ,在 “属性 ”面板 中 ,设置 
“ 值 (VD) "为 “修改 ”,“ 动 作 ” 为 “提交 表单 ”。 

(7) 按 Fl2 键 浏览 网 页 效果 如 图 5-9 所 示 。 
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六 、 思 考题 


(1) 如 何 校 验 用 户 登 录 信 息 ? 
(2) 如 何 保存 用 户 的 登录 状态 ? 
(3) 在 日 常 的 网 页 使 用 过 程 中 ,忘记 密码 如 何 找 回 ? 


5.4 管理 员 网 页 和 用 户 网 页 设计 
一 、 实 验 目 的 
通过 设计 管理 员 网 页 和 用 户 网 页 ,掌握 网 页 布局 和 静态 网 页 样式 的 设计 方法 。 
二 、 实 验 任务 


(1) 设计 如 图 5-10 所 示 的 管理 员 网 页 gly. html 。 
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图 5-10 管理 员 网 页 


(2) 设计 如 图 5-11 所 示 的 用 户 网 页 yh. html。 
(3) 设计 indexlogin. php ,实现 登录 网 页 与 管理 员 网 页 .用户 网 页 之 间 的 跳 转 。 
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图 5-11 用 户 网 页 


三 、 任务 分 析 


任务 (1) 和 任务 (2) 要 求 相 似 ,都 是 以 网 页 模板 为 基础 ,使 用 DIV 元 素 实现 网 页 布局 ， 
使 用 CSS 实现 静态 网 页 样式 设计 。 管 理 员 具有 新 增 、 修 改 和 删除 出 版 社 、 类 别 和 图 书信 
息 的 权限 ,普通 用 户 具 有 购买 图 书 和 删除 订单 的 权限 。 通 过 设置 链接 实现 管理 员 网 页 .用 
户 网 页 和 业务 逻辑 ,实现 网 页 之 间 的 联动 。 任 务 (3) 在 PHP 网 页 中 编写 程序 接收 index. 
html 传递 的 数据 ,判断 后 跳 转 到 管理 员 网 页 或 用 户 网 页 。 为 了 简化 设计 过 程 ,任务 (3) 中 
没有 对 登录 失败 情况 进行 处 理 。 


四 、 技 能 点 


(1) 二 div 之 标签 设计 。 用 于 实现 网 页 中 的 功能 分 区 ,将 页 面 分 割 为 不 同 的 部 分 , 通 
常用 于 页 面 布局 。 

(2) CSS 设计 。 层 释 样 式 表 (Cascading Style Sheet) ,是 一 组 网 页 元 素 样式 设置 规 
则 ,用 于 控制 网 页 的 外 观 。 通 过 CSS 可 以 将 网 页 的 显示 内 容 和 显示 样式 分 开 , 即 ,网 页 内 
容 保存 在 HTML 文件 中 ,显示 样式 保存 在 CSS 文件 或 HTML 文档 的 文件 头 中 。 
五 、 设计 步 又 

1. 管理 员 网 页 设计 

(1) 右 击 “文件 ”面板 中 的 muban. html, 选 择 * 编 辑 " 一 “复制 ?选项 。 右 击 “muban - 
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拷贝 .html” 文 件 ,选择 “编辑 ”一 “ 重 命名 ”选项 ,输入 gly 后 按 Enter 键 ,在 “代码 ”视图 下 
编辑 gly . html 中 内 容 。 
(2) 将 “二 div class 一 "header-t23" 二 请 登录 二 /div 之 ”替换 为 如 下 代码 : 


<div class="header-t23"> 郑 盎然 </div> 
<div class="header-t23"> 管 理 员 用 户 < /div> 
<div class="header-t23"><a href="indexlogout.php"> 退 出 登录 </a></div> 


(3) 在 “设计 ”视图 中 将 文字 "标题 替换 为 “ 郑 岩 然 的 订单 统计 ,删除 “ 内 容 ? 两 个 字 ， 
将 “属性 ”面板 中 “类 ”选择 为 areatable。 

(4) 单 击 “ 插 入 "菜单 一 “表格 ”选项 ,在 "表格 "对话 框 中 ,设置 “ 行 数 ” 值 为 1,“ 列 ” 值 为 
9, 删 除 “ 表 格 宽度 ”和 “边框 粗细 ” 值 , “标题 "选择 “顶部 ”, 单 击 “ 确 定 ” 按 钮 。 

(5) 在 “属性 ”面板 中 设置 “类 ”为 tb, 在 表格 的 单元 格 中 输入 图 5-10 所 示 表 格 的 标题 
信息 。 

(6) 单 击 状态 栏 中 二 div. area 之 标签 ,在 “代码 ”视图 下 , 单 击 所 选 代码 段 最 后 一 行 的 
行 尾 , 按 Enter 键 ,输入 以 下 代码 : 


<div class="link"><ul> 
<1i><a href= "xscbsxx.html"> 显 示 出 版 社 信息 </a></1i> 
<1i><a href="xslbxx.html"> 显 示 类 别 信息 </a></1i> 
<1li class="last"><a href="xstsxx.html"> 显 示 图 书信 息 </a></1i> 
<1i><a href="xzcbsxx.html"> 新 增 出 版 社 信息 </a></1i> 
<1i><a href="xgcbsxx.html"> 修 改 出 版 社 信 息 </a></1i> 
<1li class="last"><a href="sccbsxx.html"> 删 除 出 版 社 信 息 </a></1i> 
<1i><a href="xzlbxx.html"> 新 增 类 别 信 息 </a></1i> 
<1i><a href="xglbxx.html"> 修 改 类 别 信息 </a></1i> 
<1li class="last"><a href="sclbxx.html"> 删 除 类 别 信息 </a></1i> 
<1i><a href="xztsxx.html"> 新 增 图 书信 息 </a></1i> 
<1i><a href="xgtsxx.html"> 修 改 图 书信 息 </a></1i> 
<1i class="last"><a href="sctsxx.html"> 删 除 图 书信 息 </a></1i> 


</ul></div> 


(7) 按 F12 键 浏览 网 页 效果 如 图 5-10 所 示 。 

2. 用 户 网 页 设计 

(1) 右 击 “文件 ”面板 中 muban. html 文件 ,选择 “编辑 ”一 “复制 ”选项 。 右 击 “*muban 
- 拷贝 . html” 文 件 ,选择 “编辑 "一 “ 重 命 名 ”选项 ,输入 yh 后 按 Enter 键 ,在 “代码 ”视图 中 
编辑 yh . html 文件 。 

(2) 将 “二 div class 二 "header-t23" 放 请 登录 二 /div 二 ”替换 成 如 下 代码 : 


<div class="header-t23"> 孙 洪涛 </div> 
<div class="header-t23"> 普 通用 户 </div> 
<div class="header-t23"><a href="indexlogout. php"> 退 出 登录 < /a></div> 
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(3) 在 “设计 ”视图 中 将 文字 “标题 " 蔡 换 为 “ 孙 洪 涛 的 订单 统计 ”, 删 除 “ 内 容 ” 两 个 字 ， 
将 “属性 ”面板 中 “类 ”选择 为 areatable。 

(4) 单 击 “ 插 入 "菜单 一“ 表格 ”选项 ,在 “表格 "对话 框 中 ,设置 “ 行 数 ” 值 为 2,“ 列 ” 值 为 
9, 删 除 “ 表 格 宽度 ”和 “边框 粗细 ”的 值 , “标题” 选择 “顶部 ”, 单 击 “ 确 定 ” 按 钮 。 

(5) 在 “属性 ”面板 中 设置 “类 ”为 tb, 在 表格 的 单元 格 中 输入 图 5-11 所 示 的 表格 
内 容 。 

(6) 单 击 状态 栏 中 二 div. area 二 标签 ,在 “代码 ”视图 下 , 单 击 所 选 代 码 段 最 后 一 行 的 
行 尾 , 按 Enter 键 ,输入 以 下 代码 : 


<div class="link"><ul> 

<1i><a href="xscbsxx.html"> 显 示 出 版 社 信息 </a></1i> 

<1i><a href= "xslbxx.html "> 显示 类 别 信息 </a></1i> 

<1li class="last"><a href="xstsxx.html"> 显 示 图 书信 息 </a></1i> 

<1i><a href="gmts .html"> 购 买 图 书 </a></1i> 

<1i><a href="scdd.html"> 删 除 订单 </a></1i> 

<1li class="last"><a href="xgmm.html"> 修 改 密码 < /a>< /1i> 
</ul></div> 


(7) 按 Fl12 键 浏览 网 页 效果 如 图 5-11 所 示 。 
3. 登录 跳 转 网 页 设计 


(1) 单 击 “ 文 件 " 菜 单一 “新 建 "选项 ,选择 “页 面 类 型 "为 PHP, “布局” 为“ 无"“ 文 档 
类 型 "为 HTML5, 单 击 “ 创 建 " 按 钮 。 
(2) 在 “代码 ”视图 下 ,文件 内 容 开 始 位 置 增加 下 列 代 码 段 : 


<?php //PHP 代码 开始 标记 
$userid=""; // 初 始 化 变量 
$password=""; // 初 始 化 变量 
if (isset($_ POST['userid']) &&isset($_ POST['password'])) 
{ $userid=$ POST['userid']; // 获 取 index 网 页 传递 的 用 户 名 信息 
$password =$_POST['password']; // 获 取 index 网 页 传递 的 密码 信息 
If ($userid=="']1101010001'&&$ password== "a') 
{ header ("refresh:3;url=gly.html"); 
echo '<font color="red"> 郑 盎然 登录 成 功 ,三 秒 后 跳 转 到 管理 员 网 页 < /font>';} 
If ($userid=="'2101010001'g&g&g$password== "a') 
{ header("refresh:3;url=yh.html"); 
echo '<font color="red"> 孙 洪涛 登录 成 功 ,三 秒 后 跳 转 到 用 户 网 页 < /font>';} 
} ?>< !--PHP 代码 结束 标记 - -> 


(3) 单 击 " 文 件 " 菜 单 -保存 "选项 ,文件 名 为 indexlogin. php, 单 击 “ 保 存 " 按 钮 ;在 文 
件 面板 中 选中 indexlogin. php, 单 击 * 上 传 ?按钮 ;双击 index. html, 按 F12 键 浏 览 , 输 入 账 
号 1101010001 或 2101010001 及 密码 a。 
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(1) 如 何 设计 圆 角 区 块 ? 


(2) 管理 员 和 用 户 的 权限 有 什么 不 同 ? 
(3) 如 何 根据 不 同 的 登录 信息 ,返回 管理 员 或 用 户 页 面 ? 


5.5 显示 数据 网 页 设计 


一 、 实 验 目的 


通过 设计 显示 出 版 社 信息 网 页 .类别 信息 网 页 和 图 书信 息 网 页 ,掌握 使 用 表格 元 素 在 
静态 网 页 中 显示 数据 的 方法 。 


二 、 实 验 任务 


(1) 设计 如 图 5-12 所 示 的 显示 出 版 社 信 息 网 页 xscbsxx. html。 
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图 5-12 出 版 社 信息 网 页 


(2) 设计 如 图 5-13 所 示 的 显示 类 别 信 息 网 页 xslbxx. html。 
(3) 设计 如 图 5-14 所 示 的 显示 图 书信 息 网 页 xstsxx. html。 


兰 s 任务 分 析 


三 个 任务 要 求 相似 ,都 是 以 网 页 模板 为 基础 ,设计 包含 表格 元 素 的 静态 网 页 。 任务 
(1) 在 代码 窗口 中 编写 代码 创建 表格 ,任务 (2) 和 任务 (3) 在 设计 窗口 中 通过 可 视 化 操作 创 
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图 5-14 ”图书 信息 网 页 


建 表格 ,由 于 表格 样式 已 经 保存 在 CSS 文件 中 ,在 操作 过 程 中 需要 选择 已 有 的 样式 ,任务 
(2) 和 任务 (3) 的 设计 方法 更 为 便捷 。 


四 、 技能 点 

设计 表格 。 用 Dreamweaver 的 插入 表格 或 编写 代码 都 可 以 设计 表格 。 
五 、 设 计 步 又 

1. 显示 出 版 社 信息 网 页 设计 


(1) 右 击 “文件 ”面板 中 的 muban. html 文件 ,选择 “编辑 ”一 “复制 ”选项 。 右 击 
“muban - 拷贝 .html” 文 件 , 选 择 “ 编 辑 ”->“ 重 命名 ”选项 ,输入 xscbsxx 后 按 Enter 键 ,在 
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“代码 ”视图 下 编辑 xscbsxx. html 。 

(2) 将 “标题 ”两 个 字 改 为 “出 版 社 表 ”;“ 内容” 两 个 字 替 换 成 如 下 代码 段 : 

<table class="tb"> 
<th> 出 版 社 编码 < /th><th> 出 版 社 名 称 < /th> 
<tr><td>04</td><td> 高 等 教育 出 版 社 < /td></tr> 
<tr><td>111</td><td> 机 械 工业 出 版 社 </td></tr> 
<tr><td>115</td><td> 人 民 邮 电 出 版 社 < /td>< /tr> 

</table> 


(3) 按 F12 键 浏览 网 页 效果 如 图 5-12 所 示 。 
2. 显示 类 别 信 息 网 页 设计 


(1) 右 击 “文件 面板 中 muban. html 文件 ,选择 “编辑 ”一 “复制 ?选项 。 右 击 “muban 
- 拷贝 .html” 文 件 , 选 择 “ 编 辑 ” 一 “ 重 命名 ”选项 ,输入 xslbxx 后 按 Enter 键 ,在 “设计 ” 视 
图 下 编辑 xslbxx. html。 

(2) 在 设计 窗口 中 将 文字 “标题 "替换 为 “类 别 表 ”; 删 除 “ 内 容 " 两 个 字 , 在 “属性 ”面板 
中 选择 “类 ”为 areatable。 

(3) 单 击 “ 插 入 "菜单 一 “表格 "选项, 在“ 表格” 对话 框 中 ,设置 “ 行 数 ” 值 为 4,“ 列 ” 值 为 
2, 删 除 “ 表 格 宽度 ”和 “边框 粗细 ” 值 ,“ 标 题 "选择 “顶部 ”, 单 击 “ 确 定 ” 按 钮 。 在 “属性 ”面板 
中 设置 “类 ”为 tb, 各 个 单元 格 中 输入 图 5-13 所 示 信 息 。 

(4) 按 F12 键 浏览 网 页 效果 如 图 5-13 所 示 。 


3. 显示 图 书信 息 网 页 设计 


(1) 右 击 “文件 ”面板 中 的 muban. html, 选 择 * 编 辑 ”- "复制 ?选项 。 右 击 “muban - 
拷贝 .html" 文 件 ,选择 “编辑 ”一 “ 重 命名 ”选项 ,输入 xstsxx 后 按 Enter 键 ,在 “设计 ”视图 
下 编辑 xstsxx. html。 

(2) 在 设计 窗口 中 将 文字 “标题 "替换 为 图 书 表 ”; 删 除 “ 内 容 ” 两 个 字 , 在 “属性 ”面板 
中 选择 “类 ”为 areatable。 

(3) 单 击 “ 插 入 "菜单 一“ 表格 ”选项 ,在 “表格 "对话 框 中 ,设置 “ 行 数 ” 值 为 2,“ 列 ” 值 为 
10, 删 除 “ 表 格 宽度 "和 "边框 粗细 ”的 值 , “标题 "选择 “顶部 ”, 单 击 “ 确 定 ” 按 钮 ,在 “属性 ” 面 
板 中 设置 “类 ”为 tb; 各 个 单元 格 中 输入 图 5-14 所 示 信 息 。 

(4) 按 F12 键 浏览 网 页 效果 如 图 5-14 所 示 。 


六 、 思 考题 


(1) 如 何 使 用 Dreamweaver 的 插入 表格 功能 新 建 表格 ? 
(2) 如 何 为 表格 设计 样式 ? 
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5.6 新 增 、 修 改 和 删除 数据 网 页 设计 


一 、 实 验 目的 
通过 设计 新 增 、 修 改 和 删除 数据 记录 网 页 ,掌握 相关 网 页 之 间 的 信息 传递 方法 。 
二 、 实 验 任务 


(1) 设计 如 图 5-15 所 示 的 新 增 出 版 社 信息 的 网 页 xzcbsxx. html。 
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图 5-15 新 增 出 版 社 信息 网 页 


(2) 设计 如 图 5-16 和 图 5-17 所 示 的 修改 出 版 社 信息 的 网 页 xgcbsxx. html 和 提交 修 
改 信 息 的 网 页 xgcbsxxsub. html。 
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图 5-16 修改 出 版 社 信息 网 页 
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网 上 苑 店 网 站 示例 
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(3) 设计 如 图 5-18 所 示 的 删除 出 版 社 信息 的 网 页 sccbsxx. html 。 








图 5-18 删除 出 版 社 信息 网 页 


三 、 任 务 分 析 


三 个 任务 要 求 相似 ,都 是 以 网 页 模板 为 基础 ,使 用 表单 和 链接 实现 静态 网 页 之 间 的 数 
据 传递 。 


(1) 静态 网 页 之 间 的 数据 传递 设计 。 可 以 使 用 带 参 数 的 链接 和 表单 两 种 方式 。 
(2) 链接 设计 。 在 属性 面板 中 输入 “链接 ”的 值 后 ,需要 单 击 网 页 中 空白 处 ,改变 焦点 
使 其 生效 。 
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五 、 设 计 步 又 
1. 新 增 出 版 社 信息 网 页 设计 


(1) 右 击 “文件 ”面板 中 muban. html 文件 ,选择 “编辑 ”复制 "选项 。 右 击 “muban 
-拷贝 .html” 文 件 ,选择 “编辑 ”>“ 重 命名 ”选项 ,输入 xzcbsxx 后 按 Enter 键 , 在 “代码 ? 视 
图 中 编辑 xzcbsxx. html。 

(2) 将 “标题 "两 个 字 改 为 “新 增 出 版 社 信息 ”; 代 码 “ 二 div class 一 "areamain" 之 内 容 
二 /div 这 ”替换 成 如 下 代码 段 : 


<div class="areatable"> 
<form action="" method="post"> 
<div class="login"> 
出 版 社 编码 : <input type="text" name=" 出 版 社 编码 "><br> 
出 版 社 名 称 : <input type="text" name=" 出 版 社 名 称 "><br> 


<p><input name="sub" type="submit" value=" 提 交 " />< /p> 
(3) 按 F12 键 浏览 网 页 效果 如 图 5-15 所 示 。 
2. 修改 出 版 社 信息 网 页 设计 


(1) 右 击 “文件 ?面板 中 的 muban. html, 选 择 “ 编 辑 ” 一 “复制 "选项 。 右 击 “muban - 
拷贝 .html" 文 件 ,选择 “编辑 ”一 “ 重 命名 ”选项 ,输入 xgcbsxx 后 按 Enter 键 ,在 “设计 ” 视 
图 中 编辑 xgcbsxx. html。 

(2) 在 “设计 ”视图 中 将 文字 “标题 "替换 为 “操作 ”; 删 除 文字 内容” 在 “属性 ”面板 中 
“类 ”选择 areatable。 

(3) 单 击 “ 插 入 "菜单 一“ 表格 "选项 ,在 "表格" 对话 框 中 ,设置 “ 行 数 ” 值 为 3,“ 列 " 值 为 
3, 删 除 “ 表 格 宽度 ”和 “边框 粗细 ”的 值 , “标题 "选择 “顶部 ”, 单 击 “ 确 定 ” 按 钮 。 

(4) 在 “属性 ”面板 中 设置 “类 ”为 tb, 各 个 单元 格 中 输入 图 5-16 所 示 的 信息 。 

(5) 选中 第 2 行 第 3 列 单元 格 中 的 “修改 ”, 在 “属性 "面板 中 设置 “链接 ”为 
xgcbsxxsub. php。 

(6) 单 击 “属性 ?面板 中 的 “浏览 文件 ?图标 ,在 “选择 文件 ?对话 框 单 击 “参数 ?按钮 , 单 
击 “ 参 数 ” 对 话 框 的 “十 ”按钮 ,输入 名 称 为 cbsbm, 值 为 04; 再 单 击 “ 十 ”按钮 ,输入 名 称 为 
cbsmc, 值 为 “高 等 教育 出 版 社 ”, 最 后 单 击 “ 确 定 ” 按 钮 。 

(7) 以 相同 方法 设置 第 3 行 第 3 列 单元 格 中 的 “修改 ”, 在 “参数 ”对 话 框 单 击 “ 十 ”按钮 ， 
输入 名 称 为 cbsbm, 值 为 111, 单 击 “ 十 "按钮 ,输入 名 称 为 cbsmc, 值 为 机械 工业 出 版 社 ”。 

(8) 按 Fl12 键 浏览 网 页 效果 如 图 5-16 所 示 。 

(9) 右 击 “文件 ”面板 中 muban. html 文件 ,选择 “编辑 ”一 "复制 ?选项 。 右 击 “muban 
- 拷贝 . html” 文 件 ,选择 “编辑 ”>~”* 重 命名 ”选项 .输入 xgcbsxxsub. php 后 按 Enter 键 ,在 
“代码 ”视图 中 编辑 xgcbsxxsub. php 。 
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(10) 在 网 页 第 1 行 代码 二 !IDOCTYPE HTML 放 前 插入 以 下 代码 : 


<?php // PHP 代码 开始 标记 
$cbsbm=""; // 初始 化 变量 
$cbsmc="; // 初始 化 变量 
if (isset($ GET['cbhsbm']) &&isset($ GET['cbsmc'])) 
{ $cbsbm=$_GET['cbsbm']; // 获取 xgcbsxx 网 页 传递 的 出 版 社 编码 信息 
$cbsmc =$_GET['cbsmc'];  // 获取 xgcbsxx 网 页 传递 的 出 版 社 编码 信息 
} ?><!--PHP 代码 结束 标记 --> 
(11) 将 “标题 "两 个 字 改 为 “修改 出 版 社 信息 ”; 代 码 “ 二 div class 一 "areamain" 过 内 容 
去 /div 字 ”替换 成 如 下 代码 段 : 


<div class="areatable"> 
<form action="" method="post"> 

<div class="login"> 

<p> 出 版 社 编码 <input type="text" readonly="true" name=" 出 版 社 编码 " 
value="< ?php echo $cbsbm ?>" /></p> 

<p> 出 版 社 名 称 <input type="text" name=" 出 版 社 名 称 " 
value="< ?php echo $cbsmc ?>" /></p> 

<p><input name= "sub" type= "submit" value=" 提 交 "/></p></div></form> 

</div> 
(12) 保存 并 上 传 xgcbsxxsub. php 文件 。 双击 “文件 ”面板 中 的 xgcbsxx. html, 按 
F12 键 浏览 网 页 (如 图 5-16 所 示 ), 单 击 “ 修 改 " 链 接 浏 览 网 页 (如 图 5-17 所 示 )。 


3. 删除 出 版 社 信息 网 页 设计 


(1) 右 击 * 文 件 ” 面 板 中 muban. html, 选 择 * 编 辑 ”-~”* 复 制 ? 选 项 。 右 击 “muban - 拷 
贝 . html" 文 件 ,选择 “编辑 ”~>" 重 命名 ?选项 ,输入 sccbsxx 后 按 Enter 键 ,编辑 sccbsxx. 
html。 

(2) 在 “设计 ”视图 中 将 文字 “标题 ”替换 为 “操作 ”; 删 除 文字 内容”, 在 “属性 ”面板 中 
选择 “类 ”为 areatable。 

(3) 单 击 “ 插 入 "菜单 一“ 表格 ”选项 ,在 “表格 "对话 框 中 ,设置 “ 行 数 ” 值 为 3,“ 列 " 值 为 
3, 删 除 “ 表 格 宽度 ”和 “边框 粗细 ”的 值 , “标题 "选择 “顶部 ”, 单 击 “ 确 定 ” 按 钮 。 

(4) 在 “属性 ”面板 中 设置 “类 ”为 tb; 各 个 单元 格 中 输入 图 5-18 所 示 信 息 。 

(5) 选中 第 2 行 第 3 列 单元 格 中 的 “修改 ”, 在 “属性 ?面板 中 设置 “链接 ”为 sccbsxxsub 
. php, 以 相同 方法 设置 第 3 行 第 3 列 单元 格 中 的 “删除 ”。 

(6) 按 F12 键 浏览 网 页 效果 如 图 5-18 所 示 。 


六 、 思 考题 


(1) 如 何 设置 表单 中 文本 域 为 只 读 ? 
(2) 修改 出 版 社 信息 网 页 和 提交 修改 信息 网 页 之 间 传 递 了 什么 值 ? 
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5.7 购买 图 书 和 删除 订单 网 页 设计 


一 、 实验 目的 


通过 设计 购买 图 书 和 删除 订单 的 网 页 ,掌握 综合 使 用 表单 表格 和 链接 元 素 的 静态 网 
页 设计 方法 。 


二 、 实验 任务 


(1) 设计 如 图 5-19 和 图 5-20 所 示 的 购买 图 书 网 页 gmts. html 和 提交 购买 信息 网 页 


gmtssub. html。 
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图 5-19 ”购买 图 书 网 页 
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图 5-20 ”提交 购买 信息 网 页 


(CQ 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


(2) 设计 如 图 5-21 所 示 的 删除 订单 的 网 页 scdd. html。 
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图 5-21 删除 订单 网 页 


三 、 任 务 分 析 


两 个 任务 要 求 相 似 , 都 是 以 网 页 模板 为 基础 ,综合 使 用 表单 .表格 和 链接 元 素 完成 静 
态 网 页 设计 。 


、 技 能 点 


使 用 表单 .表格 和 链接 元 素 : 通过 综合 使 用 多 种 元 素 , 完 成 具有 复杂 交互 功能 的 静态 
网 页 设计 。 


五 、 设 计 步 又 


1. 购买 图 书 网 页 设计 


(1) 右 击 “文件 ”面板 中 muban. html 文件 ,选择 “编辑 ”复制 ? 选 项 。 庙 击 “muban 
- 拷贝. html"* 文 件 ,选择 “编辑 ”一 “ 重 命名 "选项 ,输入 gmts 后 按 Enter 键 , 编 辑 gmts. 
html。 

(2) 在 “设计 ”视图 中 将 文字 “标题 ”替换 为 “操作 ”; 删 除 文字 内容”, 在 “属性 ”面板 中 
选择 "类 ”为 areatable。 

(3) 单 击 “ 插 入 "菜单 一 “表格 ”选项 ,在 “表格 ”对 话 框 中 , 设 先行 数 ” 值 为 2,“ 列 " 值 为 
12 ,删除 “ 表 格 宽度 ”和 “边框 粗细 ”的 值 , “标题 "选择 顶部”, 单 击 “ 确 定 ” 按 钮 。 

(4) 在 “属性 ”面板 中 设置 “类 ”为 tb; 各 个 单元 格 中 输入 如 图 5-19 所 示 信 息 。 

(5) 选中 第 2 行 中 的 “购买 ”, 在 属性 面板 中 设置 “链接 ”为 gmtssub . html。 
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(6) 按 F12 键 浏览 网 页 效果 如 图 5-19 所 示 。 
(7) 右 击 “ 文 件 ” 面 板 中 muban. html, 选择“ 编辑 ”一 “复制” 选项 。 右 击 “*muban - 拷 
贝 .html" 文 件 ,选择 “ 编 辑 ” 一 “ 重 命名 ”选项 ,输入 gmtssub 后 按 Enter 键 ,编辑 gmtssub. 


html。 

(8) 在 “代码 ”视图 中 将 “标题 ”两 个 字 改 为 “购买 图 书 ”“ 内 容 ” 两 个 字 替 换 成 如 下 代 
码 段 : 

<form action="" method="post"> 


<div class="1ogin"> 
<input type="hidden" name="sh" value="978-7-04-041372- 4"/> 
<input type="hidden" name="yc" value="1" /> 
<input type="hidden" name= "mqsj" value="26.25"/> 
<p> 请 输入 册 数 <input type="text" name="cs"/></p> 
<p> 是 否 立 即 付 款 
<select class="select" name="fk" > 
<option value ="0"> 否 </option> 
<option value ="1" selected="selected"> 是 </option> 
</select></p> 
<p><input name="sub" type= "submit" value=" 购 买 "/></p> 


</div></form> 


(9) 按 F12 键 浏览 网 页 效果 如 图 5-20 所 示 。 
2. 删除 订单 网 页 设计 


(1) 右 击 “文件 ”面板 中 muban. html, 选 择 “ 编 辑 ”>“ 复 制 " 选 项 。 布 击 “*muban - 找 
贝 .html* 文 件 ,选择 “编辑 ”一 “ 重 命名 ”选项 ,输入 scdd 后 按 Enter 键 ,编辑 scdd. html。 

(2) 在 “设计 "视图 中 将 文字 “标题 "替换 为 “操作 ”; 删 除 文字 "内 容 ”, 在 “属性 ”面板 中 
选择 “类 ”为 areatable。 

(3) 单 击 “ 插 入 "菜单 一“ 表格 ”选项 ,在 “表格 "对话 框 中 ,设置 “ 行 数 ” 值 为 2,“ 列 " 值 为 
10, 删 除 “ 表 格 宽度 ”和 “边框 粗细 ”的 值 , “标题 "选择 “顶部 ”, 单 击 “ 确 定 ” 按 钮 。 

(4) 在 “属性 ?面板 中 设置 “类 ?为 tb, 各 单元 格 中 输入 图 5-21 所 示 信 息 。 

(5) 选中 第 2 行 中 的 “删除 ”, 在 “属性 ?面板 中 设置 “链接 ”为 scddsub . php。 

(6) 按 F12 键 浏览 网 页 效果 如 图 5-21 所 示 。 

(7) 双击 文件 面板 中 的 index. html, 按 F12 键 浏览 ,输入 账号 1101010001 、 密 码 a, 登 
录 后 查看 各 个 网 页 间 的 联动 效果 。 


六 、 思 考题 


(1) 在 提交 购买 信息 网 页 中 ,如 何 对 册 数 信息 进行 有 效 性 校 验 ? 
(2) 在 删除 订单 网 页 中 ,链接 “删除 ”需要 传递 哪 几 个 值 ? 
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第 6 单元 


SS 


PHP 程序 设计 


PHP(Hypertext Preprocessor, 超 文本 预 处 理 器 ) 语 言 是 全 球 最 普及 、 应 用 最 广泛 的 
互联 网 程序 设计 语言 之 一 。PHP 是 将 程序 嵌入 到 HTML 文档 中 去 执行 ,执行 效率 高 ,其 
混合 了 C、Java、Perl 以 及 PHP 自 创 新 的 语法 ,具有 简单 、 易 学 、 源 代码 开放 、 可 操纵 多 种 
数据 库 ,支持 面向 对 象 程序 设计 支持 跨 平台 操作 及 完全 免费 等 特点 。 

Dreamweaver 是 一 款 集 网 页 制作 和 网 站 管理 于 一 身 的 所 见 即 所 得 的 网 页 设计 软件 ， 
利用 它 可 以 轻而易举 地 制作 出 跨 平 台 和 跨 浏 览 器 的 网 页 。 在 Dreamweaver 中 可 以 直接 
创建 PHP 程序 ,从 而 实现 网 页 中 的 控制 功能 。 


6.1 表达 式 应 用 


一 、 实验 目 的 


掌握 PHP 中 常用 表达 式 的 运算 规则 ,能 根据 程序 需要 设计 和 测试 表达 式 ,输出 
式 的 运算 结果 。 


二 、 实验 任 务 


(1) 设计 如 图 6-1 所 示 的 表单 ,打开 网 页 后 随机 生成 变量 $x、$y 和 $z 的 值 ,其 值 为 
[0,10] 范 围 内 的 整数 。 用 户 在 变量 下 方 列 出 的 表达 式 行 后 
选择 针对 表达 式 的 判断 结果 ,页 面 下 方 列 出 了 系统 对 表达 
式 的 判断 结果 ,用 于 检测 用 户 的 判断 是 否 正确 。 单 击 “ 更 换 
数据 ?按钮 后 刷新 网 页 内 容 , 给 出 一 组 新 的 数据 ,用 于 再 次 
测试 。 

(2) 将 页 面 文件 以 文件 名 Exp6_1. PHP 保存 在 站 点 文 
件 夹 中 。 


Sx=0 $y=1 $=2 
Sx>$y 结 果 : 9 true 9 false 
Sx>$y and $x<$z 结 果 : © true © false 
Sx>$y or Sx< 红 结果 : 有 true 9 false 
JSx 结 蛙 : 9 true 9 false 

2 
$x=0 $y=1 $2=2 
Sx>$y 结果 false 
Sx>$y and $x<$z 的 结果 ; false 


Sx>$y or SX<$z 的 结果 ; true 
!$x 结 果 : true 


图 6-1 表达 式 测试 页 面 








三 、 任 务 分 析 


实现 变量 的 随机 数 赋值 可 以 使 用 PHP 函数 Rand() ,其 参数 能 够 设置 随机 生成 数据 
的 范围 。 在 PHP 代码 中 显示 生成 的 变量 值 。 变 量 值 后 的 表达 式 判 断 使 用 表单 实现 , 表 
单 中 的 表达 式 可 以 直接 输入 ,表达 式 后 的 控件 为 单 选 按钮 ， 更 换 数据 ?为 按钮 ,用 于 刷新 
页 面 。 答 案 提示 区 域 为 一 段 PHP 代码 ,判断 结果 使 用 条 件 运算 符 直 接生 成 。 


四 、 预 备 知识 


1. 随机 数 函数 Rand() 

Rand() 函 数 用 来 生成 给 定 区 间 范 围 内 的 一 个 随机 整数 ,其 函数 格式 如 下 : 

Rand (nl1,n2) 
其 生成 的 整数 范围 为 Lnl,n2], 如 果 省 略 参数 nl 和 n2, 函 数 返回 0 到 Getrandmax() 之 间 
的 任意 一 个 随机 整数 。 其 中 Getrandmax() 为 PHP 中 用 于 获取 最 大 随机 数 函 数 ,其 结果 
通常 是 32767。 

2. 条 件 运 算 符 

条 件 运算 符 是 三 元 运算 符 , 实 现 条 件 运算 需要 3 个 操作 数 , 其 语法 规则 如 下 : 

条 件 表达 式 ? 表达 式 1: 表达 式 2 

条 件 运算 符 的 执行 过 程 是 首先 计算 条 件 表 达 式 , 若 其 结果 为 True, 则 计算 表达 式 1 
并 将 表达 式 1 的 结果 作为 条 件 运算 符 的 结果 ; 若 条 件 表达 式 的 计算 结果 为 False, 则 计算 
表达 式 2 并 将 表达 式 2 的 结果 作为 条 件 运算 符 的 结果 。 


五 、 技 能 点 


(1) 创建 PHP 应 用 程序 。 在 Dreamweaver 中 创建 PHP 应 用 程序 。 

(2) 表单 应 用 。 在 页 面 中 添加 表单 。 

(3) 表单 控件 应 用 。 在 表单 中 添加 表单 控件 ,通过 修改 表单 控件 的 属性 值 及 为 具有 
控制 功能 的 控件 编写 代码 ,从 而 丰富 页 面 , 实 现 控制 功能 。 


六 、 注 意 事 项 


(1) 在 Dreamweaver 中 编写 PHP 程序 ,需要 在 Dreamweaver 中 建立 站 点 并 配置 服 
务 器 信息 , 选 定 服务 器 配置 中 的 “测试 "项 。 
(2) PHP 代码 使 用 二 ?PHP 开始 ,使 用 ? 之 结束 ,其 间 可 以 书写 任意 多 行 代码 。 
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(3) 页 面 中 每 行 表 达 式 后 的 两 个 单 选 按钮 的 标签 分 别 为 True 和 False, 构 成 一 组 , 形 
成 互 斥 选项 。 即 ,选择 了 True 按钮 , 则 False 按钮 的 选项 就 自动 取消 ,反之 亦 然 。 设 计 中 
只 需 将 每 行 的 两 个 单 选 按 钮 命名 成 相同 的 名 字 即 可 (name 属性 值 相同 ) 。 


七 、 实 验 步 又 
1. 创建 PHP 程序 


(1) 启动 Dreamweaver, 单 击 “ 文 件 ” 菜 单一 “新 建 ” 选 项 。 
(2) 在 “新 建文 档 ” 对 话 框 中 选择 “页 面 类 型 "为 PHP, 单 击 “ 创 建 "按钮 。 
(3) 在 “代码 ”视图 中 将 标签 二 title 二 与 二 /title 二 之 间 的 内 容 修 改 为 “表达 式 测试 ”。 
(4) 单 击 "文件 ?菜单 一 “保存 ?项 ,选择 保存 位 置 ( 如 …\xampp\htdocsNrczp) 后 输入 
文件 名 exp6_1. php, 单 击 “ 保 存 ” 按 钮 。 
2. 创建 PHP 代码 定义 变量 并 显示 
在 “代码 ?视图 中 一 body 过 与 一 /body 之 标签 之 间 输 入 如 下 代码 。 
<?php 
$x=rand(0,10); $y=rand(0,10);$z=rand(0,10); // 定 义 变量 并 用 随机 数 函 数 赋值 


echo '$x=',$x,' $y=',$y,' $2z=',$z,'<br>'; // 在 页 面 中 显示 变量 名 及 其 值 


?> 


3. 插入 表单 及 表单 控件 


(1) 单 击 “ 文 档 " 工 具 栏 中 的 “设计 ”视图 ,光标 定位 在 页 面 中 PHP 提示 符 后 , 按 Enter 
键 增加 新 行 , 单 击 “ 插 入 "菜单 一 “表单 “表单 "项 。 

(2) 在 表单 中 输入 文字 *$ x 二 $y 结果 :”, 单 击 “ 插 入 "菜单 “表单” 一“ 单 选 按钮 ”一 
在 对 话 框 中 “标签 "项 后 输入 true 确定 "按钮 , 单 击 插入 的 单 选 按钮 图 标 ,在 “属性 ?面板 
中 将 “ 单 选 按钮 "的 值 修改 为 radiol 。 

(3) 同样 的 方法 在 插入 的 单 选 按钮 后 再 插入 一 个 单 选 按钮 ,其 标签 设置 为 False, 其 
属性 面板 中 * 单 选 按钮 "的 值 修改 为 radiol 。 

(4) 在 表单 第 一 行内 容 的 结尾 按 Enter 键 ,在 新 的 一 行 中 输入 表达 式 “$x> $y and 
$x 二 $z 结果 :”, 在 表达 式 后 同样 插入 两 个 单 选 按钮 ,在 “属性 ”面板 中 将 其 “ 单 选 按 钮 ”的 
性 值 均 设置 为 radio2 。 

(5) 同样 的 方式 增加 其 他 行 表达 式 内 容 , 内 容 参 看 图 6-1。 

(6) 在 最 后 一 个 表达 式 后 按 Enter 键 增加 一 行 , 单 击 “ 插 入 ”菜单 一“ 表单 ”一 “按钮 ” 
一 “确定 ”按钮 ,在 “属性 "面板 中 ,将 “ 值 ”设置 为 “更 换 数据 ”。 


4. 创建 PHP 代码 生成 答案 
单 击 "文档 ”工具 栏 中 的 “代码 ?视图 ,在 标签 过 ,form 之 和 过 /body 之 之 间 输 入 如 下 
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代码 。 


<?php 
echo '$x=',$x,' $y=',$y,' $z=',$z,"<br>"; // 输 出 变量 及 其 值 
echo '$x>$y 结果 ', $x>$y?'true':'false', '<br>'; /输出 表达 式 及 判断 结果 
echo '$x>$y and $x<$z 的 结果 :', ($x>$y and $x<$2z)?'true':'false', '<br>'; 
echo '$x>$y or $x<$z 的 结果 :'，, ($x>$y or $x<$z)?'true':'false', '<br>'; 
echo '!1$x 结果 :',!$x ?'true':'false','<br>'; 

?> 


5. 运行 程序 查看 结果 


单 击 " 文 件 ” 菜 单一 ”保存 "项 保存 程序 , 单 击 "文档 "工具 栏 中 "在 浏览 器 中 预览 /调试 ” 
图 标 , 选 择 “ 预 览 在 IExplore" 项 ,在 正 浏 览 器 中 查看 页 面 执行 效果 。 


八 、 思 考题 
(1) 程序 中 能 和 否 实现 随机 生成 任意 长 度 任意 内 容 的 字符 串 ? 需要 用 到 哪些 PHP 函数 ? 


(2) 程序 中 用 户 答案 的 选择 若 不 用 单 选 按钮 ,还 可 以 用 什么 控件 实现 ? 
(3) 针对 本 程序 还 可 以 有 哪些 修改 完善 建议 ? 


6.2 数组 定义 


一 、 实 验 目 的 
了 解数 组 的 基本 概念 ,掌握 PHP 中 数组 的 定义 .赋值 及 引用 方法 。 
二 、 实验 任 务 


(1) 创建 PHP 应 用 程序 SY6_2. PHP, 在 程序 中 定义 一 维 索 引 数 组 $ xl 用 于 存储 
gwb 表 中 最 低 学 历 信息 ,定义 一 维 关联 数组 $ ypz 存储 ypryb 表 中 一 名 应 聘 者 的 部 分 资 
料 信息 。 

(2) 使 用 explode() 函数 将 字符 串 “ 无 ;学 士 ; 双 学 十 ;硕士 ;博士 "中 的 内 容 转 换 为 数 
组 元 素 保存 在 数组 $ xw 中 。 

(3) 分 别 显示 各 数组 的 长 度 并 用 下 标 方式 显示 数组 中 各 元 素 的 值 。 

(4) 使 用 print_r() 函 数 显示 数组 $ ypz 的 内 容 。 


三 、 任务 分 析 


在 PHP 程序 中 创建 数组 可 以 使 用 array([key 二 记 jvalue,…) 函 数 , 其 中 value 为 数 
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组 元 素 , 省 略 *key 一 二 "选项 或 key 参数 使 用 数字 时 数组 即 为 索引 数组 ,而 key 为 元 素 名 
时 其 数组 为 关联 数组 ,显示 数组 中 的 元 素 可 以 按照 数组 下 标 引 用 数组 元 素 ,也 可 以 用 
Print_t() 函 数 直接 输出 数组 中 的 全 部 内 容 。 


四 、 预 备 知识 


1. 通过 array() 函 数 创 建 数组 


通过 函数 array() 创 建 数组 ,其 使 用 格式 有 如 下 几 种 。 
(1) 定义 索引 数组 $ gsmc, 其 含有 3 个 元 素 , 其 下 标 分 别 是 1.2 和 3。 


$gsmc=array(1=>" 工 商 前 进 支行 ",2=>" 腾 飞 总 公司 ",3=>" 医 大 一 院 ") ; 

(2) 定义 索引 数组 $gsmec, 其 含有 3 个 元 素 , 其 下 标 分 别 是 0、1 和 2。 

$gsmc=array ("工商 前 进 支 行 ", "腾飞 总 公司 ", "医大 一 院 "); 

(3) 定义 索引 数组 $gsmc, 通过 赋值 形式 确认 数组 3 个 元 素 , 其 下 标 分 别 是 1、2 
和 3。 

$gsmc=array (); 

$gsmc [1]=" 工 商 前 进 支行 ";$gsmc[2]=" 腾 飞 总 公司 ";$gsmc[3]=" 医 大 一 院 "; 

(4) 定义 关联 数组 $ ypz, 其 含有 4 个 元 素 , 其 下 标 分 别 是 元 素 名 称 。 


$ypz=array ("证 件 号 " =>"229901199503121538", "姓名 " =>" 刘 德 厚 ", "笔试 成 绩 " = > 85， 
"面试 成 绩 " =>90)7 


2. 通过 explode() 函数 创建 数组 

通过 explode() 函数 创建 数组 ,函数 使 用 格式 如 下 。 

explode (分 隔 符 ,字符 串 , [数组 长 度 ]); 

例如 ,语句 “$ xw 一 explode(";",， "无 ;学士 ; 双 学 士 :硕士 :博士 "); ”省 略 数组 长 度 
时 ,explode() 函 数 按 字符 串 中 内 容 确 定数 组 长 度 , 当 给 出 数组 长 度 小 于 字符 串 中 内 容 长 
度 时 , 按 给 出 长 度 转换 字符 串 内 容 , 例 如 ,给 定语 句 *$ xw 二 explode(";", "无 ;学 土 ; 双 学 
十 ;硕士 ;博士 ",3);” 则 数组 长 度 为 3, 其 中 的 3 个 元 素 分 别 是 "无 "、" 学 士 " 和 " 双 学 士 ; 硕 
主 ? 竺 主 "。 


3. count() 函数 统计 数组 中 元 素 的 个 数 

count() 用 于 统计 数组 中 含有 元 素 的 个 数 , 其 使 用 格式 如 下 。 
count (数组 名 ) ; 

4. print_r() 函 数 实现 数组 元 素 的 输出 

print_r() 函 数 用 来 输出 表达 式 的 值 , 其 使 用 格式 如 下 。 
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(@ 


print r (表达 式 ); 
当 表达 式 为 数组 名 时 ,其 按 数组 元 素 的 先后 顺序 输出 数组 下 标 及 对 应 元 素 的 值 。 


五 、 技 能 点 


(1) 数组 的 创建 。 能 够 在 PHP 中 创建 数组 并 对 数组 元 素 进 行 赋值 。 
(2) 通过 下 标 访问 数组 元 素 。 在 程序 中 通过 下 标 访 问 索 引 数 组 或 关联 数组 中 元 素 。 
(3) 使 用 print_rO 〇 函数 输出 数组 元 素 。 使 用 print_r() 函 数 输出 数组 中 的 内 容 。 


六 、 注 意 事 项 


(1) 数组 可 以 定义 为 索引 数组 或 关联 数组 ,使 用 下 标 方式 访问 数组 元 素 时 , 需 按照 数 
组 的 定义 格式 给 出 相应 的 下 标 值 。 

(2) 若 数组 a 中 的 每 个 元 素 都 是 一 个 数组 , 则 数组 a 就 构成 了 多 维 数组 。 二 维 数组 
通常 用 来 保存 表格 形式 的 数据 。 

(3) 程序 中 通常 使 用 循环 控制 结构 访问 数组 中 的 每 个 元 素 。 


七 、 实 验 步骤 


1. 创建 PHP 应 用 程序 


(1) 在 Dreamweaver 中 单 击 “ 文 件 " 菜 单一 “新 建 " 项 ,在 “新 建文 档 ” 对 话 框 中 选择 “页 
面 类 型 "为 PHP, 单 击 “ 创 建 " 按 钮 。 

(2) 在 “代码 ”视图 中 将 标签 二 title 二 与 二 /title 二 之 间 的 内 容 修 改 为 : 数组 定义 , 单 击 
“文件 "菜单 一 “保存 ”, 在 “另存 为 "对话 框 中 输入 文件 名 SY6_2. PHP, 单 击 “ 保 存 ” 按 钮 。 


2. 定义 数组 、 输 出 数组 中 的 元 素 
在 “代码 "视图 中 ,在 标签 二 body 二 与 二 /body 二 之 间 输 入 如 下 代码 定义 数组 。 


<?php 
$xl=array ("无 要 求 ", "专科 ", "本 科 ", "研究 生 ", "博士 ") ; 
$ypz=array ("身份 证 号 "=>"229901911503121538", "姓名 "=>" 刘 德 厚 "," 婚 否 "=>0， 
"所 学 专业 "=>" 会 计 学 ", "移动 电话 "=>"13988699912"," 固 定 电 话 "=>"0431- 
85166032"); 
$xw=explode (";", "无 ;学 士 ; 双 学 士 ;硕士 ;博士 "); 
echo "数组 \$xl 中 共有 :", count ($x1), "个 元 素 ", "<br>"; 
echo "数组 \$xl 中 的 内 容 是 : ", $x1[0],",",$x1[1]," ,",$x1[2],", 
"$x1[3]," ,",$x1[4],"<br>"; 
echo "数组 \$ ypz 中 共有 :", count ($ypz)," 个 元 素 ","<br>"; 
echo "数组 \$ ypz 中 的 内 容 是 :",$ ypz[" 身 份 证 号 "]," ,",$ypz[" 姓 名 "]," ，"， 
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$ypz[" 婚 否 "]?" 已 婚 ":" 未 婚 ","”,",$ypz[" 所 学 专业 "]," ，,"， 
$ypz[" 移 动 电话 "]," ，",$ ypz[" 固 定 电话 "],"<br>"; 

echo "数组 \$xw 中 共有 :", count ($xw), "个 元 素 ", "<br>"; 

echo "数组 \$xw 中 的 内 容 是 : ", $xw[0]," ,",$Sxw[1]," ,",$Sxw[2]," ,", 
$xw[3]," ,", $xw[4],"<br>"; 

print r($ypz);?> 


3. 查看 程序 执行 效果 


单 击 "文件 菜单 一 保存 ”项 保存 文件 , 单 击 "文档 ”工具 栏 中 “在 浏览 器 中 预览 / 调 
试 ? 图 标 ,选择 “预览 在 IExplore”" 项 ,在 IE 浏览 器 中 查看 页 面 执行 效果 。 


八 、 思 考题 
(1) 在 PHP 中 可 以 使 用 几 种 方法 定义 数组 ? 一 个 定义 的 关联 数组 能 否 使 用 索引 方 


式 引 用 其 数组 元 素 ? 
(2) 若 改 用 循环 控制 结构 输出 数组 元 素 , 则 如 何 修改 SY6_2. PHP 中 的 程序 代码 ? 


6.3 证 分 支 程序 设计 
一 、 实 验 目 的 
掌握 PHP 中 放 分 支 语句 的 用 法 ,能 够 应 用 if 语句 实现 程序 中 的 判断 功能 。 
二 、 实 验 任务 
设计 登录 页 面 程序 SY6_3. PHP, 如 图 6-2 所 示 , 输 入 用 户 名 user01 和 密码 1001 单 


击 “ 登 录 ” 按 钮 ,系统 打开 另 一 个 程序 文件 SY6_3_1. PHP( 如 图 6-3 所 示 )。 输 入 其 他 用 户 
名 或 密码 时 系统 提示 “用 户 名 或 密码 错误 ,请 重新 输入 !1”。 














用 户 各 称 : 用 户 和 名、 密码 正确 ， 可 以 使 用 本 系统 ! 
登录 裤 码 
EE 
图 6-2 登录 页 面 内 容 图 6-3 登录 成 功 后 的 页 面 
三 、 任务 分 析 


表单 及 表单 控件 用 来 实现 页 面 中 的 控制 功能 。 登 录 页 面 程序 中 首先 插入 一 个 表单 ， 
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在 表单 中 插入 2 个 文本 域 控件 和 1 个 按钮 控件 ,按钮 的 执行 代码 中 通过 if 分 支 语 句 判 断 
用 户 名 及 密码 是 否 正 确 , 根 据 判断 的 结果 选择 执行 不 同 的 程序 代码 。 在 网 页 中 打开 一 个 
新 的 页 面 有 多 种 方法 ,本 实验 使 用 JavaScript 代码 实现 。 用 户 名 及 密码 判断 成 功 后 的 页 
面 SY6_3_1. PHP 没有 设计 具体 功能 ,只 是 给 出 了 一 段 文字 提示 ,可 根据 需要 修改 添加 。 


四 、 预 备 知识 


1. PHP 中 的 if 语句 


分 支 语句 用 于 判断 程序 中 的 多 种 情况 并 根据 判断 结果 分 别 进行 处 理 ,分 支 结构 语句 
流程 如 图 6-4 所 示 。 


TFCRf 


了 1 
语句 组 1 语句 组 2 


图 6-4 分 支 结构 流 程 图 





























if (条 件 ) 

{ 语句 组 1 } 
Else 

{ 语句 组 2 } 


让 诸 句 中 可 以 省 略 else 及 其 后 的 语句 组 2, 这 种 应 用 即 构成 单 分 支 语句 。 其 中 的 语 
名 组 1 及 语句 组 2 都 可 以 是 让 分 支 语句 ,这 种 用 法 称 为 主语 句 的 嵌 套 ,利用 计 语 句 的 嵌 
套 能 够 实现 多 分 支 程序 判断 。 


2. 在 PHP 代码 中 打开 一 个 新 的 页 面 


在 PHP 中 有 多 种 方法 可 以 打开 一 个 新 的 页 面 文件 。 若 使 用 JavaScript 方法 , 则 只 需 
在 PHP 代码 中 添加 如 下 语句 输出 二 script 全 与 二 /script 盖 标签 。 


echo "<script language='javascript'>window.location=' 页 面 文件 名 '< /script>"; 
其 中 页 面 文件 名 需要 给 出 页 面 文件 的 完整 名 称 。 
3. 在 PHP 代码 中 使 用 提示 对 话 框 


提示 对 话 框 是 网 页 中 常用 的 一 种 信息 提示 方法 ,使 用 JavaScript 方 法 同样 能 快速 实 
现 提示 对 话 框 功能 ,其 PHP 代码 如 下 。 
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echo "<script language= 'javascript'>alert(' 提 示 信 息 ')</script>"; 
例如 ,在 程序 中 给 出 如 下 提示 信息 , 则 其 对 应 的 程序 界面 如 图 6-5 所 示 。 


echo "<script language= 'javascript'>alert (' 用 户 名 或 密码 错误 ， 
请 重新 输入 !')</script>"; 











图 6-5 提示 对 话 框 的 界面 


五 、 技 能 点 


(1) 让 语句 的 应 用 。 能 够 使 用 话语 句 的 多 种 格式 设计 分 支 程序 。 
(2) PHP 中 使 用 JavaScript 代码 。 掌 握 PHP 中 嵌入 JavaScript 代码 的 方法 。 
(3) PHP 中 实现 提示 对 话 框 。 能 够 在 PHP 中 通过 JavaScript 代码 实现 提示 对 话 框 。 


六 、 注 意 事项 


(1) 网 站 通常 由 多 个 页 面 文件 构成 ,多 个 页 面 文件 通常 都 保存 在 站 点 文件 夹 下 ,程序 
中 出 现 调用 时 可 以 不 用 给 出 文件 存放 位 置 。 

(2) 让 分 支 语句 语法 结构 中 ,条 件 成 立 或 不 成 立 ,其 后 只 能 有 一 条 语句 。 若 判断 后 需 
要 执行 多 条 语句 完成 控制 功能 ,可 将 多 条 语句 使 用 一 对 花 括号 括 起 来 形成 复合 语句 ,在 
PHP 中 复合 语句 是 一 条 语句 。 

(3) 让 分 支 语句 条 件 后 不 能 添加 分 号 ,因为 单独 的 分 号 就 是 一 条 语句 , 称 为 空 语句 ， 
出 现 空 语句 时 , 空 语句 即 成 为 分 支 的 执行 语句 。 


七 、 实 验 步 又 


1. 创建 主页 面 程序 SY6_3_1.PHP 


(1) 启动 Dreamweaver, 单 击 “ 文 件 " 菜 单一 “新 建 " 项 ,选择 “页 面 类 型 "为 PHP, 单 击 
“创建 ?按钮 。 

(2) 在 文档 的 “代码 ?视图 中 将 标签 title 之 与 二 /title 之 之 间 的 文字 修改 为 “网 站 首 
页 ”, 在 二 body> 与 二 /body> 之 间 加 入 文字 “用户 名 、 密 码 正确 ,可 以 使 用 本 系统 !”。 
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(3) 单 击 “ 文 件 " 菜 单一 “保存 ”项 ,在 “另存 为 ”对 话 框 中 输入 文件 名 SY6_3_1. PHP， 
单 击 “ 保 存 ” 按 钮 完成 主页 面 程序 设计 。 


2. 创建 登录 页 面 程 序 SY6_3. PHP 


(1) 创建 PHP 文档 并 修改 文档 的 页 面 标题 。 在 Dreamweaver 中 单 击 “ 文 件 ” 菜 单一 “新 
建 ? 项 一 选择 “页 面 类 型 ?为 PHP 习 单 击 “ 创 建 " 按 钮 ,在 文档 的 “代码 ”视图 中 将 标签 二 title 二 
与 一 /title> 之 间 的 文字 修改 为 "系统 登录 ”。 

(2) 在 文档 中 创建 表单 。 单 击 “ 文 档 ” 工 具 栏 中 的 “设计 ”视图 ,在 “设计 ”视图 中 单 击 
“插入 "菜单 一 “表单 ”>“ 表 单项 ,在 页 面 中 添加 表单 。 

(3) 在 表单 中 创建 表单 控件 。 单 击 “ 插 入 ”菜单 一 “表单 >“ 文本 域 " 项 ,在 “输入 标签 
辅助 功能 属性 ”对 话 框 中 “标签 ”项 后 输入 文字 "用 户 名 称 : ”, 单 击 “ 确 定 ” 按 钮 。 单 击 将 光 
标定 位 于 表单 中 新 添加 文本 域 控件 后 , 按 Enter 键 增加 新 行 , 同 样 的 方式 插入 另 一 个 文本 
域 控 件 并 将 其 标签 命名 为 登录 密码 : ”。 青 次 增加 新 行 后 单 击 “ 插 入 ”菜单 “表单 ”一 
“按钮 ”一 “确定 ”按钮 。 单 击 表单 中 的 按钮 ,在 “属性 ”面板 中 将 其 “ 值 ” 属 性 修改 为 登录 ”。 

(4) 为 “登录 ”按钮 设计 代码 。 单 击 “ 文 档 " 工 具 栏 中 的 “代码 ”视图 ,在 标签 二 /form 二 
与 一 /body> 之 间 输 入 如 下 PHP 代码 ,实现 按钮 控件 的 控制 功能 。 


<?php 

if(isset($_POST["button"])) // 判 断 登 录 按 钮 被 按 下 

{ $username=$_ POST["textfield"]; // 取 用 户 名 称 文本 域 中 的 内 容 
$password=$_POST["textfield2"]; // 取 登录 密码 文本 域 中 的 内 容 
if ($username=='user01' and $password=="1001") 
// 判 断 用 户 名 称 及 口令 是 否 正确 

echo"<script language= 'javascript'> 
window.location= "sy6 3 1.php'</script>"; 

else 


echo "<script language= 'javascript'> 


alert (' 用 户 名 或 密码 错误 ,请 重新 输入 !')</script>";}?> 


(5) 保存 文件 内 容 : 单 击 “ 文 件 ” 菜 单一 “保存 ”, 在 “另存 为 ”对 话 框 中 输入 文件 名 
SY6_3. PHP, 单 击 “ 保 存 ” 按 钮 。 


3. 查看 程序 的 执行 效果 


单 击 “ 文 档 " 工 具 栏 中 “在 浏览 器 中 预览 /调试 "图 标 , 选 择 “ 预 览 在 IExplore” 项 ,在 IE 
浏览 器 中 查看 页 面 执 行 效果 。 在 登录 页 面 中 输入 任意 用 户 名 称 和 用 户 密码 ,查看 系统 的 
提示 信息 ,输入 用 户 名 user01 及 密码 1001 查看 主页 面 打 开 的 效果 。 


八 、 思 考题 


(1) 在 PHP 代码 中 除 使 用 JavaScript 代码 实现 打开 其 他 页 面 外 ,还 有 哪些 方法 可 以 
实现 该 功能 ? 
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(2) 登录 页 面 中 若 要 设 定 3 次 登录 限制 , 即 , 用 户 输 入 的 用 户 名 或 密码 3 次 错误 后 即 
关闭 页 面 , 则 程序 需要 做 哪些 修改 ? 

(3) 一 个 应 用 系统 通常 有 多 名 注册 用 户 ,程序 中 该 如 何 管理 登录 用 户 名 及 其 密码 ? 
如 何 保障 用 户 密码 的 安全 ? 


6.4 多 分 支 程 序 设 计 


一 、 实 验 目的 


掌握 PHP 中 多 分 支 语句 switch 的 用 法 ,能 够 应 用 switch 语句 实现 程序 中 的 多 分 支 
判断 。 


二 、 实 验 任务 


(1) 设计 程序 SY6_4. PHP ,执行 该 文件 时 根据 系统 当前 时 间 提 示 问 候 语 ,界面 如 


图 6-6 所 示 。 
vserO01 


(8 点 到 11 点 )、 中 午 (Q1 点 到 13 点 )、 下 午 (13 点 到 17 点) 

图 6-6 各 序 执行 界 
和 晚上 (17 点 到 第 二 日 6 点 前 ) 。 多 分 支 程序 执行 界面 
三 、 任 务 分 析 


问候 语 中 根据 系统 时 间 的 不 同 对 应 不 同 的 提示 信息 ,属于 多 种 条 件 判断 ,可 以 使 用 多 
分 支 语句 switch 实现 判断 结果 ,也 可 以 使 用 让 语句 的 嵌 套 实现 。 简 化 问题 ,用 户 名 使 用 
固定 名 称 user001 ,程序 中 直接 显示 判断 结果 。 


四 、 预 备 知识 


1. 这 语 句 实现 多 分 支 程序 结构 
在 PHP 中 让 语句 的 基本 格式 如 下 。 
if( 条 件 ){ 语句 组 1} else { 语句 组 2} 


若 语句 组 1 或 语句 组 2 仍 为 f 语句 则 构成 if 语句 的 嵌 套 ,其 可 实现 多 分 支 结构 
判断 。 


2. switch 语句 实现 多 分 支 程 序 结构 
在 PHP 中 switch 语句 的 基本 结构 如 下 。 
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switch (变量 或 表达 式 ) 
{case 值 1 或 表达 式 1: 
语句 组 1; 
[ break; ] 
case 值 2 或 表达 式 2: 
语句 组 2; 


[ break; ] 


default: 
默认 语句 组 ;} 


3. 获取 当前 系统 时 间 


获取 当前 系统 日 期 时 间 可 以 使 用 PHP 函数 date() ,通过 参数 设置 可 以 分 别 获得 不 同 
格式 日 期 ,时间 值 。 使 用 函数 date("G") 可 获取 当前 系统 时 间 中 24 小 时 制 的 小 时 值 。 

PHP 系统 默认 时 间 格 式 为 英国 夏令 时 ,要 正确 显示 当前 时 间 值 还 需要 将 时 间 格式 设 
置 为 北京 时 间 , 其 使 用 的 函数 及 格式 如 下 。 


date_default_timezone_set("PRC") 7 


五 、 技 能 点 


(1) 让 语句 的 拒 套 。 通 过 让 语 句 的 嵌 套 实现 多 分 支 程序 结构 。 
(2) switch 语句 。 使 用 switch 语句 实现 多 分 支 程序 结构 。 
(3) 获取 系统 时 间 。 正 确 设置 系统 所 在 的 时 区 ,使 用 函数 date() 获 取 系 统 日 期 时 间 。 


六 、 注 意 事 项 


(1) 用 这 语句 实现 多 分 支 , 除 使 用 if 语句 的 嵌 套 格式 外 ,还 可 以 使 用 elseif 格式 

(2) switch 语句 中 的 变量 或 表达 式 的 类 型 通常 为 整 型 或 字符 型 ,case 后 可 以 使 用 常 
量 匹 配 switch 后 的 数据 类 型 ,也 可 以 直接 使 用 表达 式 进行 判断 ,每 一 组 case 语句 之 后 通 
常 使 用 break 结束 分 支 。 


七 、 实 验 步 又 


1. 创建 PHP 应 用 程序 


(1) 在 Dreamweaver 中 单 击 "文件 莱 单 ~ 新建 ?项 ,在 "新建 文档 "对话 框 中 选择 “页 
面 类 型 "为 PHP , 单 击 “创建 ?按钮 关闭 “新建 " 对 话 框 。 
(2) 单 击 “文件 菜单 ~ 保存 ”, 在 “另存 为 ?对 话 框 中 输入 文件 名 SY6_4. PHP, 单 击 
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“保存 ”按钮 。 
2. 输入 PHP 程序 代码 
在 代码 视图 中 标签 二 body 过 与 一 /body 二 之 间 输 入 如 下 PHP 代码 。 


<?PHP 


date default timezone set ("PRC"); // 设 置 北京 时 区 


$user="user001"; // 给 出 固定 用 户 名 
$a=date("G"); // 获 取 当 前 24 小 时 制 的 小 时 值 
switch ($a) // 多 分 支 判 断 小 时 值 ,给 出 对 应 的 问候 区 间 


{ case $a>=6and $a<8: 
$b=" 早 上 ";break; 
case $a>=8 and $a<11: 
$b=" 上 午 ";break; 
case $a>=11 and $a<13: 
$b=" 中 午 ";break; 
case $a>=13 and $a<17: 
$b=" 下 午 ";break; 
default: 
$b=" 晚 上 "; } 
echo $user."".$b." 好 !"."<br>"; // 显 示 判 断 结果 
?> 


3. 查看 程序 执行 结果 


单 击 “ 文 件 "菜单 “保存 "项 保存 文件 内 容 , 单 击 “ 文 档 " 工 具 栏 中 “在 浏览 器 中 预览 / 
调试 图标, 选择 “预览 在 IExplore "项 ,在 IE 浏览 器 中 查看 页 面 执行 效 果 。 


4. switch 语句 中 case 后 的 常量 值 实现 


以 上 PHP 代码 switch 语句 中 case 分 支 使 用 了 表达 式 进 行 判断 , 若 用 常量 值 表示 ,其 
多 分 支 语句 代码 如 下 。 


Switch(Sa) 
{ case 6: case 7: 
$b=" 早 上 ";break; 
case 8: case 9: case 10: 
$b=" 上 午 ";break; 
case 11: case 12: 
$b=" 中 午 ";break; 
case 13: case 14: case 15: case 16: 
$b=" 下 午 ";break; 
default: 
$b=" 上 晚上 ";} 
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其 用 法 为 多 路 case 共用 同一 组 语句 ,需要 完整 写 出 每 一 组 case 值 。 
5. 用 证 语句 实现 多 分 支 
用 计 语 句 的 嵌 套 格式 实现 多 分 支 ,其 多 分 支部 分 的 程序 代码 如 下 。 


if($a>=6 and $a<8) 


$b=" 早 上 "; 
else 
if($a>=8 and $a<11) 
$b=" 上 午 "; 
else 
if($a>=11 and $a<13) 
$b=" 中 午 "， 
else 
if($a>=13 and $a<17) 
$b=" 下 午 "; 
else 
Sb=" 晚 上 "; 


在 让 结构 中 每 个 判断 后 不 需要 break 语句 。 如 果 计 结 构 中 某 个 判断 要 执行 多 条 语 
句 , 则 需要 将 多 条 语句 用 一 对 花 括号 括 起 来 构成 复合 语句 。 


八 、 思 考题 


(1) 让 语句 构成 的 多 分 支 和 switch 语句 相 比 有 哪些 不 同 ? 
(2) 若 将 证 语句 构成 的 多 分 支 改 为 elseif 结构 ,该 如 何 书写 对 应 部 分 的 程序 代码 ? 


6.5 循环 程序 设计 
一 、 实 验 目的 
掌握 PHP 中 循环 语句 的 基本 功能 ,能 够 运用 循环 及 循环 的 嵌 套 实现 复杂 控制 过 程 。 
二 、 实 验 任务 
设计 程序 SY6_5.PHP, 用 来 实现 乘法 口诀 表 的 输出 ,运行 效果 见 图 6-7。 


三 任务 分 析 


图 6-7 中 使 用 表格 显示 乘法 口诀 表 , 表 格 中 表 头 内 容 固定 , 表 体 根 据 行列 内 容 显示 相 
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图 6-7 ”乘法 口诀 表 页 面 


关 的 数据 ,所 以 程序 中 先 插入 一 个 1 行 10 列 的 表格 ,之 后 在 单元 格 中 输入 表 头 内 容 , 最 后 
在 表格 内 编写 程序 实现 表 体内 容 的 输出 。 表 体 程序 采用 标准 的 二 层 循环 嵌 套 格式 ,外 层 
循环 控制 行 ,内 层 循环 控制 列 , 输 出 内 容 为 算式 及 其 前 后 的 单元 格 标签 , 若 无 计算 内 容 则 
只 需 输出 单元 格 开始 和 结束 标签 。 


、 预 备 知识 


1. PHP 中 的 循环 程序 结构 

循环 结构 有 while .do…while for 及 foreach 四 种 ,for 循环 的 语句 格式 如 下 : 
for (表达 式 1; 表 达 式 2; 表 达 式 3){ 循环 体 语句 } 

若 循 环 体 只 包含 一 条 语句 ,一 对 花 括号 可 以 省 略 。 

2. 表格 相关 的 标签 


表格 是 网 页 中 一 个 复杂 的 结构 ,需要 多 个 HTML 标签 配合 使 用 。 其 中 二 table 二 … 
一 /table 之 用 于 定义 表格 ,一 caption 二 … 一 /caption 二 用 于 定义 表格 的 标题 信息 ,一 tr 二 … 
所 /tr> 用 于 定义 表格 中 的 一 行 ,二 th>… 志 /th> 用 于 定义 一 个 表 头 单元 格 , 一 td 二 … 
去 /td> 用 于 定义 一 个 普通 的 数据 单元 格 。 


五 、 技 能 点 


(1) 创建 表格 。 在 网 页 中 插入 表格 并 设计 表格 内 容 。 
(2) 在 PHP 中 使 用 循环 程序 结构 。 使 用 循环 结构 实现 计算 功能 。 


六 、 注 意 事项 


(1) for 循环 的 表达 式 1 通常 用 于 循环 控制 变量 赋 初 值 ,表达 式 2 通常 为 循环 的 判断 
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条 件 , 表 达 式 3 为 循环 变量 改变 值 , 程 序 中 可 以 根据 需要 省 略 部 分 或 全 部 表达 式 。 

(2) 使 用 函数 echo 输出 多 项 内 容 时 ,可 以 选择 使 用 逗号 分 隔 , 也 可 以 使 用 字符 串 连 
接 运算 符 (. ) 将 要 输出 的 内 容 连接 成 一 个 字符 串 输出 。 当 字符 串 连接 运算 符 连 接 的 内 容 
是 数值 常量 时 需要 在 数值 前 后 分 别 输入 空格 分 隔 数据 。 

(3) 插入 表格 时 给 出 表格 行 、 列 数 及 表格 宽度 。 对 于 一 个 多 列表 格 ,系统 通常 会 按照 
表格 中 内 容 的 长 短 自动 调整 每 列 的 宽度 。 


七 、 实 验 步 又 
1. 创建 PHP 应 用 程序 


(1) 在 Dreamweaver 中 单 击 “ 文 件 ” 菜 单一 "新建" 项, 在“ 新建 文档” 对 话 框 中 选择 “页 
面 类 型 "为 PHP, 单 击 "创建 "按钮 。 

(2) 在 “代码 "视图 中 将 标签 一 title> 与 一 /title> 之 间 的 内 容 修改 为 "乘法 口诀 表 ”, 单 击 
“文件 ”菜单 保存”, 在 “另存 为 "对话 框 中 输入 文件 名 SY6_5. PHP, 单 击 "保存 ?按钮 。 


2. 插入 表格 标题 及 表格 表 头 

单 击 " 文 档 ? 工 具 栏 中 的 “设计 ?视图 , 单 击 "插入 ?菜单 "表格 ”在 图 6-8 所 示 的 “ 表 
格 ” 对 话 框 中 “表格 大 小 ”区 域 分 别 输入 行 数 1、 列 数 10、 表 格 宽度 850 ,边框 粗细 2 .单元 格 
边 距 1、 单 元 格 间 距 1, 单 击 选 择 标题 区 域 为 “顶部 ”在 “辅助 功能 ”区域 中 “标题 "后 输入 
“乘法 口诀 表 ”, 单 击 “ 确 定 ” 按 钮 创建 表格 。 








行 数 : 1 到 : 10 
委 格 克朗 : 850 [像素 xz] 
边框 拒 绍 2。 登 素 
音 元 格 边 距 1 
单元 格 间 下 :1 ”四 


























图 6-8 “表格 ”对 话 框 


单 击 设计 视图 中 表格 的 第 一 个 单元 格 ,输入 文字 “ 行 ”, 之 后 逐个 单 击 其 后 的 每 个 单元 
格 ,分 别 输入 数字 1 一 9 。 
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3. 使 用 PHP 代码 生成 表格 的 表 体 部 分 
单 击 “ 文 档 ” 工 具 栏 中 的 “代码 ”视图 ,在 标签 二 /tr 二 > 和 一 /table 二 之 间 输 入 如 下 代码 。 


<?PHP 
for ($m=1; $m<=9; Sm++) // 外 层 循环 ,控制 行 
{ Echo "<tr><td>", $m."</td>";  // 每 行 开始 输 出 行 开始 标签 , 行 首 单元 格 及 序号 
for($n=1; $n<=9; Sn++) // 内 层 循环 ,控制 列 数 
if($n<=$m) // 判 断 是 否 输出 内 容 
Echo "<td>".$n."*",$m"=",$mx* $n,"</td>"; // 输 出 单元 格 内 容 
else 
Echo "<td>","</td>"; // 输 出 空白 单元 格 
Echo "</tr>"; // 输 出 行 结束 标签 
} 
?> 


4. 查看 程序 执行 效果 

单 击 "文件 "菜单 “保存” 项 保存 文件 , 单 击 * 文 档 " 工 具 栏 中 “在 浏览 器 中 预览 / 调 
试 " 图 标 ,选择 “预览 在 IExplore” 项 ,在 IE 浏览 器 中 查看 页 面 执 行 效果 。 
八 、 思 考题 


(1) 若 将 程序 中 for 循环 改 为 do…while 循环 或 while 循环 ,应 该 如 何 修改 程序 ?能 
否 将 程序 中 的 循环 改 为 foreach 循环 ? 
(2) 程序 中 若 不 显示 空白 单元 格 ,应 该 如 何 修改 程序 代码 ? 


6.6 数组 应 用 
一 、 实 验 目的 


了 解数 组 的 基本 概念 ,掌握 PHP 中 数组 的 定义 、 赋 值 及 引用 方法 ,能 够 熟练 应 用 与 
数组 相关 的 函数 实现 数组 操作 。 


二 、 实验 任 务 


(1) 程序 中 定义 一 维 数组 $ gsmc ,将 工商 前 进 支行 .腾飞 总 公司 、 医 大 一 院 、 食 府 快 餐 
店 、 阳 光 物 业 管理 公司 、 高 等 教育 出 版 社 6 个 公司 名 称 保存 到 该 数组 中 。 

(2) 页 面 中 设计 2 列表 格 , 通 过 循环 结构 将 数组 元 素 输 出 到 表格 中 ,如 图 6-9 所 示 。 

(3) 表格 下 方 设计 表单 ,通过 文本 域 输入 公司 名 称 , 单 击 “ 查 找 ” 按 钮 后 在 数组 中 查找 
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所 输入 的 公司 名 称 , 根 据 查找 结果 提示 找到 或 未 找到 。 

















图 6-9 数组 查询 应 用 界面 


三 、 任 务 分 析 


在 PHP 程序 中 创建 数组 可 以 使 用 array() 函数, 数组 元 素 作为 函数 参数 直接 给 出 。 
页 面 中 的 表格 通过 Dreamweaver 中 “插入 "菜单 “表格 ”实现 ,表格 中 表 体 部 分 使 用 循环 
结构 逐 行 生成 。 表 单 中 添加 控件 文本 域 及 按钮 ,查找 输入 公司 名 称 是 否 在 数组 中 使 用 函 
数 in_array() 实 现 , 查 找 结果 直接 显示 在 界面 中 。 


四 、 预 备 知识 


1. foreach 循环 结构 操作 数组 


foreach 循环 结构 是 仅 应 用 于 数组 的 循环 结构 ,用 于 遍历 数组 中 的 每 个 元 素 ,其 使 用 
格式 如 下 。 


foreach( 数 组 名 as 变量 名 ) 
{ 语句 组 ; } 


foreach 循环 结构 遍历 数组 时 ,每 次 将 一 个 数组 元 素 值 保存 在 给 定 的 变量 名 中 ,语句 
组 中 通过 变量 名 实现 数组 的 遍历 要 求 。 

2. in_array() 函 数 实现 数组 元 素 的 查找 

in_array() 函数 用 来 实现 数组 元 素 的 查找 ,其 使 用 格式 如 下 。 

in_array (要 查找 的 内 容 , 数 组 名 ); 

若 要 查找 的 内 容 在 数组 中 ,函数 返回 True, 否 则 返回 False。 


(1) 数组 的 创建 。 能 够 在 PHP 中 创建 数组 并 赋值 数组 元 素 。 
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(2) foreach 循环 结构 遍历 数组 。 程 序 中 使 用 循环 结构 访问 数组 中 的 每 个 元 素 。 
(3) in_array() 丽 数 查找 数组 元 素 。 在 数组 中 查找 给 定 的 值 。 


六 、 注 意 事项 


(1) 在 页 面 中 插入 表格 后 ,在 设计 视图 中 单 击 表 格 中 任意 单元 格 ,系统 默认 设置 环境 
中 表格 下 方 会 显示 表格 宽度 , 拖 动 表格 边框 线 可 以 调整 单元 格 或 表格 的 大 小 。 若 单 击 表 
格 中 任意 单元 格 后 表格 下 方 不 显示 宽度 线 , 只 需 右 击 表格 中 任意 单元 格 选择 “表格 "菜单 
一 “表格 宽度 "项 即 可 显示 表格 宽度 线 。 

(2) 数组 可 以 定义 为 索引 数组 ,也 可 以 定义 为 关联 数组 。 若 数组 a 中 的 每 个 元 素 都 
是 一 个 数组 , 则 数组 a 就 构成 了 多 维 数 组 。 二 维 数 组 通常 用 来 保存 表格 形式 的 数据 。 


七 、 实 验 步骤 


1. 创建 PHP 应 用 程序 


(1) 在 Dreamweaver 中 单 击 “ 文 件 " 菜 单一 “新 建 " 项 ,在 “新 建文 档 ” 对 话 框 中 选择 “页 
面 类 型 "为 PHP, 单 击 “ 创 建 "按钮 。 

(2) 在 “代码 ”视图 中 将 标签 天 title 之 与 二 /title 之 之 间 的 内 容 修改 为 “公司 查询 ”, 单 击 
“文件 "菜单 一 “保存 ”, 在 “另存 为 ”对话 框 中 输入 文件 名 SY6_6. PHP, 单 击 “ 保 存 ” 按 钮 。 


2. 插入 表格 标题 及 表格 表 头 

(1) 单 击 “ 文 档 "工具 栏 中 的 “设计 ”视图 , 单 击 “ 插 入 "菜单 一 “表格 ”, 在 图 6-8 所 示 的 
“表格 "对 话 框 中 “表格 大 小 ”区 域 分 别 输入 行 数 1、 列 数 2、 表 格 宽度 330、 边 框 粗细 2, 单元 
格 边 距 1、 单 元 格 间 距 1, 单 击 选择 “标题 区域 为 “顶部 ”, 在 “辅助 功能 "区 域 中 “标题 "后 输 
人 “公司 名 称 表 ”, 单 击 “确定 ”按钮 创建 表格 。 

(2) 单 击 拖 动 表格 第 一 个 单元 格 的 右边 界线 ,将 第 一 个 单元 格 宽度 调整 为 55。 

3. 使 用 PHP 代码 生成 表格 的 表 体 部 分 

单 击 ” 文 档 " 工 具 栏 中 的 “代码 "视图 ,在 标签 二 /tr 之 和 去 /table> 之 间 输 入 如 下 代码 。 


<?php 
$gsmc=array ("工商 前 进 支 行 ", "腾飞 总 公司 ", "医大 一 院 "," 食 府 快餐 店 "， 
"阳光 物业 管理 公司 "," 高 等 教育 出 版 社 "); ”// 定 义 数 组 并 赋值 数组 元 素 


$i=1; // 定 义 表 中 序号 变量 
foreach($gsmc as $gs) //foreach 循环 结构 ,访问 数组 中 每 个 元 素 
{ echo "<tr><td>".$i."</td>"; // 生 成 序号 单元 格 

echo "<td>$gs</td></tr>"; // 生 成 公司 名 称 单元 格 

Si++， // 序 号 变量 增 1 


2 
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4. 插入 表单 及 表单 控件 


(1) 单 击 * 文 档 工 具 栏 中 “设计 ”视图 , 单 击 “ 插 和 人" 菜单 一 “表单 ”一 “表单 ”项 ,在 给 出 
的 表单 界面 中 按 Enter 键 增加 新 行 。 

(2) 单 击 * 插 入 "菜单 ~ 表单 ”~* 文 本 域 "项 ,在 * 输 入 标签 辅助 功能 属性 "对 话 框 中 
“标签 ”后 输入 “公司 名 称 : ”, 单 击 “ 确 定 "按钮 。 

(3) 光标 定位 于 文本 域 后 按 Enter 键 , 单 击 * 插 入 "菜单 ~“ 表单 ”按钮 ", 单 击 * 确 
定 "按钮 , 单 击 表单 中 的 按钮 ,将 * 属 性 "面板 中 的 * 值 "属性 修改 为 "查找 "。 


5. 为 按钮 编写 代码 
单 击 " 文 档 ” 工 具 栏 中 ”代码 ?视图 ,在 标签 过 /form 之 与 二 /body 二 之 间 输 入 如 下 


代码 。 
<?php 
if(isset ($_POST["button"])) // 判 断 按钮 按 下 
{ $gs=$_POST["textfield"]; ”// 提 有 取 文 本 域 中 的 内 容 
if(in array($gs,$gsmc)) // 在 数组 $gsmc 中 找到 输入 的 公司 名 
echo "所 查询 公司 有 招聘 信息 !"."<br>"; 
else // 在 数组 $gsmc 中 未 找到 输入 的 公司 名 
echo "所 查询 的 公司 没有 招聘 信息 !!1"."<br>"; 
} 
?> 


6. 查看 程序 执行 效果 


单 击 “ 文 件 "菜单 一 “保存 "项 保存 文件 , 单 击 “ 文 档 " 工 具 栏 中 “在 浏览 器 中 预览 /调试 ” 
图 标 , 选 择 “ 预 览 在 IExplore” 项 ,在 IE 浏 览 器 中 查看 页 面 执行 效果 。 


八 、 思 考题 
(1) 程序 中 车 不 用 foreach 循环 结构 遍历 数组 元 素 , 改 为 使 用 for 循环 结构 或 while 
循环 结构 ,该 如 何 修改 程序 ? 


(2) 程序 中 若 不 用 in_array() 函数 查找 给 定 的 内 容 是 否 在 数组 中 ,还 可 以 使 用 哪些 方 
法 完成 查找 功能 ? 


6.7 自 定 义 函数 应 用 


一 、 实验 目 的 


掌握 自 定义 函数 的 定义 方法 ,能 够 应 用 自 定义 函数 实现 程序 功能 。 
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二 、 实 验 任务 


(1) 设计 自 定义 函数 echo123() ,调用 该 函数 可 以 按 指定 的 字体 、 字 号 和 颜色 显示 给 
定 的 文字 内 容 , 函 数 格式 如 下 : 


echol123($ str,$ fontname, $size,$ color); 


函数 调用 中 若 不 指定 字体 , 则 输出 文字 为 宋体 , 若 不 指定 字号 , 则 输出 文字 字号 为 
20, 若 不 指定 颜色 , 则 输出 文字 为 黑色 。 

(2) 在 页 面 中 调用 自 定义 函数 echol123() 分 别 按 华文 隶书 52 号 字 红 色 、 华 文 隶 书 35 
号 字 绿 色 ,楷书 26 号 字 、 楷 书 及 不 指定 字体 字号 颜色 显示 文字 人 才 招 聘 信息 管理 系统 ”， 
页 面 结果 如 图 6-10 所 示 。 
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图 6-10 自 定 义 函数 显示 文字 


ll 


、 任 务 分 析 


自 定义 函数 通常 用 来 实现 程序 中 的 特定 运算 。 设 计 函 数 按 给 定格 式 输出 文字 ,函数 
不 需要 返回 值 , 答 出 的 文字 .字体 .字号 和 颜色 4 项 内 容 可 以 依次 作为 函数 参数 ,不 给 出 某 
参数 时 函数 自动 指定 参数 的 值 , 这 在 函数 定义 中 称 为 参数 的 默认 值 , 其 可 以 在 函数 参数 中 
通过 赋值 运算 给 出 。 函 数 体 中 使 用 div 元 素 完成 字体 .字号 和 颜色 的 设置 ,文字 输出 直接 
使 用 echo 函数 实现 。 


、 预 备 知识 


1. 函数 的 定义 格式 
自 定义 函数 的 基本 格式 如 下 : 


function 函数 名 (函数 参数 列表 ) 
{ 语句 组 ; } 


若 函 数 具 有 多 个 参数 ,参数 之 间 逗 号 分 隔 。 函 数 若 有 返回 值 , 则 使 用 return 语句 送 
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回 函数 结果 。 
2. 自 定义 函数 的 调用 
自 定义 函数 的 调用 与 系统 函数 相同 ,其 格式 如 下 : 
函数 名 ( 实 参 列表 ) ; 
自 定义 函数 可 以 按 函数 语句 调用 ,车 函数 有 返回 值 同样 可 以 出 现在 表达 式 中 。 
3. 函数 的 默认 参数 


在 调用 函数 时 可 以 省 略 某 些 参数 ,函数 规定 省 略 的 参数 按 默认 值 处 理 。 可 以 使 用 默 
认 值 的 参数 在 定义 函数 时 用 赋值 运算 给 定 默认 值 ,echo123() 函 数 的 默认 值 设置 如 下 。 

echo123 ($ str,$fontname= "宋体 ",$size=20,S$Scolor="#000000") 

车 函数 定义 中 有 多 个 具有 默认 值 的 参数 , 则 调用 函数 时 使 用 默认 值 必 须 从 右 侧 参数 
开始 且 连 续 , 和 否则 系统 提示 错误 。 

4. div 元 素 


div 标签 是 HTML 中 用 于 实现 网 页 布局 的 标签 ,div 元 素 即 指 div 的 起 始 标签 .结束 
标签 及 二 者 之 间 所 包含 的 内 容 , 通 常用 于 实现 元 素 内 容 的 精确 定位 和 样式 的 统一 规划 。 
使 用 div 元 素 定义 字体 、 字 号 和 文字 颜色 ,其 格式 如 下 : 


<div style="font-family: 字 体 ;font- size: 字 号 px; color: 颜 色 "> 
要 输出 的 文字 < /div> 


其 中 颜色 可 以 使 用 # RRGGBB、rgb(r,g.b) 或 颜色 名 称 表示 。 


五 、 技 能 点 


(1) 自 定义 函数 。 掌 握 PHP 中 自 定义 函数 的 定义 及 调用 方法 。 
(2) 函数 参数 的 默认 值 。 掌 握 PHP 中 自 定义 函数 参数 设置 默认 值 的 方法 。 


六 、 注 意 事 项 
(1) 自 定义 函数 名 称 不 能 与 系统 函数 名 重 名 , 通常 自 定义 函数 名 应 该 简洁 、 见 名 
知 意 。 


(2) 在 函数 体内 字符 串 中 出 现 函 数 参 数 时 ,可 以 使 用 一 对 花 括 号 将 函数 参数 括 起 来 ， 
其 格式 即 为 取 参 数 的 值 。 
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七 、 实 验 步 又 


1. 创建 PHP 应 用 程序 


(1) 在 Dreamweaver 中 单 击 “ 文 件 " 菜 单一 “新 建 "项 ,在 “新 建文 档 ” 对 话 框 中 选择 “页 
面 类 型 "为 PHP, 单 击 “ 创 建 " 按 钮 。 

(2) 在 “代码 ”视图 中 将 标签 二 title 志 与 过 /title 志 之 间 的 内 容 修改 为 “ 自 定义 函数 显 
示 文 字 ”, 单 击 “ 文 件 " 菜 单一 “保存 ”, 在 “另存 为 "对话 框 中 输入 文件 名 SY6_7. PHP, 单 击 


2. 设计 自 定义 函数 echo123() 并 调用 其 显示 文字 
在 “代码 ?视图 中 标签 二 body 之 与 二 /body 之 之 间 输 入 如 下 程序 代码 。 


<?php 
// 定 义 函数 echo123() ,其 有 4 个 参数 ,无 返回 值 
function echol123 ($str,$ fontname=" 宋 体 ",$size=20,$color="#000000") 
{ $style=" font - family: {$fontname }; font - size: {$size} px; color: 
{$color}"y 


echo "<div align='left' style='{$style}'>{$str}</div>\n";} 


// 以 下 语句 分 别 调用 自 定义 函数 显示 文字 ,部 分 参数 使 用 默认 值 
echo123 ("人 才 招 聘 信息 管理 系统 ", "华文 隶书 ","52", "#FF0000"); 
echo123 ("人 才 招 聘 信息 管理 系统 ", "华文 隶书 "，35, "#00FF00"); 
echo123 (" 人 才 招 聘 信息 管理 系统 ", "楷书 ",26) 7 

echo123 (" 人 才 招 聘 信息 管理 系统 "， "楷书 ") 7 

echo123 ("人 才 招 聘 信息 管理 系统 ") 7 


?> 






3. 查看 程序 执行 效果 


单 击 “ 文 件 "菜单 “保存 ”项 保存 文件 , 单 击 “ 文 档 " 工 具 栏 中 “在 浏览 器 中 预览 / 调 
试 "图 标 ( 妃 .) ,选择 “预览 在 IExplore” 项 ,在 IE 浏览 器 中 查看 页 面 执行 效果 。 右 击 “ 浏 
览 " 页 面 一 “查看 源 ” 项 ,得 到 的 结果 如 下 。 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtmll/DTD/xhtmll-transitional.dtd"> 
<html xmlns= "http://www.w3.org/1999/xhtml"> 
<head><meta http-equiv="Content-TYPe" content="text/html; charset=utf-8" /> 
<title> 自 定义 函数 显示 文字 < /title>< /head> 
<body> 
<div align='left' style= 'font-family: 华 文 隶书 ; font- size:52px; 
color:#FF0000'"> 人 才 招 聘 信息 管理 系统 </div> 
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<div align='left' style= 'font-family: 华 文 隶书 ; font- size:35px; 
color:#00FF00'> 人 才 招 聘 信息 管理 系统 < /div> 

<div align='left' style='font-family: 楷 书 ; font-size:26px; 
color:#000000'"> 人 才 招聘 信息 管理 系统 < /div> 

<div align='left' style='font- family: 楷 书 ; font- size:20px; 
color:#000000'> 人 才 招 聘 信息 管理 系统 < /div> 

<div align='left' style='font- family: 宋 体 ; font- size:20px; 
color:# 000000'> 人 才 招 聘 信息 管理 系统 < /div> 

</body></html> 


八 、 思 考题 
(1) PHP 支持 按 值 传递 参数 、 通 过 引用 传递 参数 以 及 默认 参数 ,在 函数 的 定义 中 如 


何 区 分 这 几 种 方式 ?其 使 用 上 有 哪些 差别 ? 
(2) 若 自 定义 函数 调用 后 需要 返回 多 个 值 ,这 样 的 函数 功能 如 何 实现 ? 
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动态 网 页 程序 设计 


动态 网 页 主要 解决 通过 浏览 器 访问 数据 库 的 问题 ,通常 需要 运行 程序 访问 数据 库 。 
在 程序 访问 数据 库 之 前 ,需要 连接 数据 库 服务 器 和 选择 数据 库 。 


7.1 网 页 模板 及 数据 库 连 接 接口 设计 


一 、 实 验 目 的 


学 习 PHP 程序 连接 MySQL 数据 库 及 设置 字符 集 的 方法 ,掌握 访问 数据 库 的 接口 程 
序 设计 技能 ,为 动态 网 页 搭建 环境 和 创建 模板 。 


二 、 实验 任务 


(1) 设计 图 7-1 所 示 的 网 页 模板 mb. php, 其 中 包括 页 头 区 域 (header. inc. php) ,操作 


页 头 区 域 





吉 人 与 研究 中 心 制作 


bE 


操作 区 域 








页 脚 区 域 





图 7-1 网 页 模板 的 结构 


区 域 和 页 脚 区 域 (footer. inc. php)。 页 头 区 域 中 包含 导航 和 Logo 图 片 两 部 分 ,导航 中 显 
示 浏 览 网 页 的 日 期 和 星期 ,车 未 登录 ,显示 “请 登录 ”; 若 已 登录 则 显示 用 户 名 、 身 份 及 退出 
项 。 页 脚 区 域 中 显示 版 权 文字 及 制作 年 份 。 

(2) 在 Dreamweaver 中 创建 MySQL 数据 库 服务 器 的 连接 。 其 中 “连接 名 称 ” 为 
wssd,“MySQL 服务 器 ”为 localhost, “用 户 名 ”为 root, “密码 ”为 空 , “数据 库 ” 设 置 为 


wssd。 


三 任务 分 析 


在 网 页 中 访问 MySQL 数据 库 , 需 要 创建 网 页 到 数据 库 服 务 器 的 连接 ,之 后 才能 访问 数 
据 库 中 的 资源 。 任 务 (2) 通 过 可 视 化 操作 方法 ,能 够 快速 地 创建 数据 库 服务 器 的 连接 。 任 务 
(1) 分 别 创建 页 头 文件 和 页 脚 文 件 ,再 利用 文件 包含 函数 将 这 两 个 文件 加 载 到 网 页 模板 中 。 


四 、 预 备 知识 


(1) header 函数 。 可 用 于 设置 页 面 编 码 及 实现 页 面 延 时 跳 转 功能 。 

Oa 设置 页 面 编码 “header("Content-type: text/html; charset 二 编码 方式 ");”。 

@ 延 时 跳 转 :在 PHP 中 可 以 利用 此 函数 实现 网 页 的 定时 跳 转 ,语法 格式 为 :header 
("refresh: 时 间 ;url 二 网 址 "), 其 中 时 间 单 位 是 秒 。 

(2) SESSION。 也 称 为 会 话 , 是 指 客户 端 与 服务 器 进行 的 一 个 通信 期 ,在 浏览 某 个 网 
站 时 ,从 进入 网 站 开始 到 断 开 服务 器 所 经 历 的 时 间 就 是 一 次 会 话 。 使 用 会 话 的 基本 步 又 
如 下 : 

OQ@ 初始 化 SESSION :调用 session_start 函数 ,语法 格式 为 session_start() 。 

@ 创建 SESSION 变量 :利用 PHP 超 全 局 数组 $_SESSION 定义 数组 元 素 ,语法 格 
式 为 $_SESSION[ mame"] 二 'value', 其 中 name 表示 元 素 下 标 ,value 表示 值 。 

@ 使 用 SESSION 变量 :利用 PHP 预定 义 的 超 全 局 数组 $_SESSION。 

@ 注销 SESSION :可 以 用 unset 函数 注销 某 个 会 话 元 素 ,语法 格式 为 unset( 会 话 元 
素 ) 。 也 可 以 用 session_destroy 函数 终结 整个 会 话 , 语 法 格式 为 session_destroy() 。 














(3) 创建 MySQL 连接 : 单 击 数据 库 面 板 中 的 “十 ”一 ”MySQL 连接 ”选项 ,在 
“MySQL 连接 ”对 话 框 (如 图 7-2 所 示 ) 中 创建 MySQL 数据 库 服务 器 连接 。 
MySQL 连接 
连接 名 称 : wssd | [确定 ] 
参数 设置 区 MySQL 服务 器 : 1ocalhost | ，，， 

NEN 

| 医 荆 肖 
: 天 数据 库 
WE “选取 " 按 角 

















图 7-2 数据库 服务 器 连接 
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(4) 创建 MySQL 数据 库 连 接 后 ,在 站 点 文件 夹 中 自动 创建 Connections 文件 夹 , 其 
中 包含 一 个 与 连接 名 称 相同 的 连接 配置 文件 ,如 图 7-3 所 示 。 
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图 7-3 ”Connections 文件 夹 及 连接 配置 文件 


(5) 在 站 点 文件 夹 WSSD 的 子 目 录 CSS 中 需要 创建 样式 文件 WSSD. CSS, 文 件 中 的 
样式 代码 参考 附录 A。 


五 、 技 能 点 


(1) 建立 数据 库 服 务 器 的 连接 。 在 数据库” 面板 中 完成 。 

(2) 向 MySQL 数据 库 服务 器 发 送 SQL 语句 。 用 MySQL_Query 函数 实现 。 
(3) 选择 当前 数据 库 。 用 MySQL_Select_DB 函数 选择 当前 数据 库 。 

(4) 设置 字符 集 。 用 Set Names 语句 设置 。 


六 、 注 意 事 项 


(1) 创建 数据 库 服务 器 连接 时 ,需要 “测试 ”成功 后 再 单 击 “ 确 定 ” 按 钮 。 

(2) 创建 了 数据 库 连 接 后 ,所 连接 的 数据 库 并 不 会 成 为 当前 数据 库 , 需 要 调用 
MySQL_Select_DB 函数 选择 当前 数据 库 。 

(3) 为 了 保证 客户 端 与 服务 器 端 能 正常 传输 包含 汉字 的 数据 和 SQL 语句 ,在 选择 数 
据 库 后 .发送 SQL 语句 前 ,必须 发 送 Set Names 语句 对 字符 集 进 行 设置 。 

(4) 在 设计 数据 库 服务 器 连接 程序 之 前 ,应 该 正确 配置 当前 站 点 及 其 服务 器 。 


七 、 设计 步 又 
1. 设计 网 页 模板 


(1) 创建 页 头 网 页 。 在 “文件 "面板 中 设置 wssd 为 “当前 站 点 ”, 单 击 “ 文 件 菜 单一 
“新 建 "选项 ,选择 “空白 页 ”“ 页 面 类 型 "为 PHP,“ 布 局 ”为 无 , 单 击 “ 创 建 "按钮 。 在 “ 代 
码 " 视 图 中 ,删除 全 部 源 代码 后 ,输入 如 下 代码 : 


<?php 
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if (!isset($_SESSION)) session _ start (); // 启动 SESSION 
header ("Content-type: text/html; charset=utf-8"); // 设置 网 页 编码 方式 ?> 
<div id="header"> 
<div class="header-tl"><a href="http://localhost/wssd"> 首 页 </a></div> 
<div class="header-t23"><?php echo date("Y-m-d");// 显示 当前 日 期 ?></div> 
<div class="header-t23"><?php echo date ("1"); // 显示 当前 星期 ?>< /div> 


<?php 
if (isset($_SESSION['islogin']) && $_SESSION['islogin'] ==1) // 若 已 经 登录 
{ echo '<div class="header-t23">'.$_ SESSION["username"].'</div>'; 
// 显示 用 户 名 
if ($_SESSION['role'] =='0') // 根据 角色 分 别 显示 用 户 身份 
echo '<div class="header-t23"> 普 通用 户 </div>'; 
if ($_SESSION['role'] == "1°') 


echo '<div class="header-t23"> 管 理 员 用 户 </div>'; 
echo '<div class= "header-t23"><a href="logout.act.php"> 退 出 </a></div>'; 
} 
else 
echo '<div class="header-t23"> 请 登录 </div>'; // 若 未 登录 显示 "请 登录 "? > 
</div> 
<div class="wrap"><div class="1ogo"> 
<img src="images/logo.jpg"><!--images 文件 夹 中 保存 图 像 资源 - -> 
</div></div> 


(2) 保存 页 头 文件 。 单 击 “ 文 件 " 菜 单一 “另存 为 "选项 ,选择 站 点 wssd 根 目 ,输入 文 
件 名 header. inc. php, 单 击 “ 保 存 " 按 钮 ,关闭 此 文件 。 

(3) 创建 页 脚 网 页 。 单 击 " 文 件 ? 菜 单一 "新建 ? 选 项 ,选择 “空白 页 ”设置 “页 面 类 型 ” 
为 PHP,“ 布 局 ”为 无 , 单 击 “ 创 建 "按钮 。 在 “代码 "视图 中 ,删除 全 部 源 代码 后 ,输入 如 下 
代码 : 


<div class="footer"> 

<p> 吉 林 大 学 公共 计算 机 教学 与 研究 中 心 < /p> 

<p><?php echo date ("Y"); // 显示 当前 4 位 年 份 ?> 年 制作 < /p> 
</div> 


(4) 保存 页 脚 文 件 。 单 击 “ 文 件 " 菜 单 习 “另存 为 ”选项 ,选择 wssd 目录 ,输入 文件 名 
footer. inc. php, 单 击 “ 保 存 ” 按 钮 ,关闭 此 文件 。 

(5) 新 建 网 页 。 单 击 “ 文 件 ” 一 “新 建 " 菜 单项 ,选择 “空白 页 ", “页面 类 型 "为 PHP， 
“布局 ”为 无 , 单 击 “ 创 建 " 按 钮 。 在 “代码 "视图 中 ,删除 全 部 源 代码 后 ,输入 以 下 代码 : 


<?php if (!isset ($_SESSION)) session start(); // 启动 SESSION ?> 
<html><head><title> 模 板 </title> 

< !-- 链 接 层 倒 样式 表 文 件 --> 

<link rel="stylesheet" type="text/css" href="css/wssd.css"></head> 
<body class="bg"> 

<?php 


(6 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


header ("Content-type: text/html; charset=utf-8"); // 设置 网 页 编码 方式 为 utf-8 
include ("header .inc.php"); // 包含 页 头 文件 ?> 
<div class="wrap"><div class="area"> 
<div class="areatitle"> 标 题 </div> 
<div class="areatable"> 添 加 内 容 </div> 
</div></div> 
<?php include ("footer .inc.php"); // 包含 页 脚 文件 ?> 
</body></html> 


(6) 预览 并 保存 。 按 F12 键 ,保存 文件 为 mb. php ,并 浏览 网 页 效果 如 图 7-1 所 示 。 
2. 创建 数据 库 服务 器 连接 


(1) 创建 数据 库 服 务 器 连接 。 单 击 “ 数 据 库 ” 面 板 的 “十 ”一 “MySQL 连接 ”选项 ,在 
“MySQL 连接 ”对 话 框 中 ,设置 “连接 名 称 ” 为 wssd,“MySQL 服务 器 "为 localhost, “用 户 
名 ”为 root,“ 密 码 ” 为 空 ,“ 数 据 库 ” 为 wssd, 单 击 “ 测 试 ”按钮 ,显示 “成 功 创建 连接 脚本 ” 
后 , 单 击 “ 确 定 ” 按 钮 。 

(2) 设置 当前 数据 库 和 字符 集 。 在 “文件 ”面板 的 WSSD 站 点 的 本 地 视图 下 , 单 击 文 
件 夹 Connections 的 “十 ”, 双 击 打 开 文 件 wssd. PHP。 单 击 * 文 档 ” 工 具 栏 上 的 “代码 ” 按 
钮 ,在 代码 "? >” 的 前 面 输入 如 下 两 行 代码 : 


MySQL Select DB ("wssd"); // 选择 当前 数据 库 为 wssa 
MySQL Query("Set Names 'utf-8'") 7 // 将 字符 集 设置 为 utf-8 


关闭 并 保存 当前 文件 wssd. php。 
八 、 思 考题 
(1) 如 果 没 有 在 连接 文件 中 添加 语句 MySQL_Query("Set Names 'utf-8") ,将 会 产 


生 什 么 问题 ? 还 可 以 使 用 什么 方法 解决 这 个 问题 ? 
(2) 为 什么 要 设计 网 页 模板 ? 


7.2 用 户 登录 /退出 的 网 页 设计 
一 、 实 验 目的 
以 Dreamweaver 为 开发 工具 ,学 习 设 计 接 收 用 户 数据 的 表单 。 
二 、 实 验 任务 


设计 网 上 书店 网 站 的 首页 及 用 户 登录 页 面 ,如 图 7-4 所 示 。 


第 7 单元 动态 网 页 程序 设计 


网 此 区 店 网 站 示例 


Eb 


峰 号 ，[2101010002 
密码 ，eeeeed 
登录 


图 7-4 首页 即 用 户 登 录 页 面 





(1) 以 普通 用 户 身份 登录 后 ,显示 页 面 如 图 7-5 所 示 。 
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图 7-5 普通 用 户 登 录 后 的 页 面 


(2) 以 管理 员 身 份 后 ,显示 页 面 如 图 7-6 所 示 。 


三 、 任 务 分 析 


利用 表单 及 控件 设计 用 户 登 录 界 面 ,接收 账号 和 密码 后 ,在 会 员 表 (hyb) 中 进行 查 
找 。 若 账号 和 密码 均 正 确 , 则 登录 成 功 , 设 置 相 关 的 SESSION 元 素 ; 若 账号 或 密码 有 错 ， 
则 提示 重新 登录 。 

利用 网 页 模板 进一步 设计 ,如 果 没 有 登录 , 则 显示 登录 界面 ;车 已 经 有 用 户 登录 , 则 根 
据 用 户 的 角色 分 别 显示 不 同 的 功能 界面 。 
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图 7-6 管理 员 登 录 后 的 首页 界面 


四 、 预 备 知识 


(1) 表单 .控件 及 其 相关 属性 。 
(2) PHP 的 md5() 函数 用 于 实现 信息 加 密 。 用 法 为 :md5( 字 符 串 )。 


五 、 技 能 点 


(1) 引用 超 全 局 数组 $_POST。 用 于 接收 表单 的 POST 方法 发 送 来 的 数据 。 
(2) 调用 header 函数 。 设 置 页 面 的 编码 方式 ;实现 定时 跳 转 。 
(3) 设计 会 话 。 用 于 各 网 页 之 间 传 递 数 据 。 


六 、 注 意 事 项 


由 于 会 员 表 (hyb) 中 的 密码 字段 保存 加 密 后 的 信息 ,因此 在 设计 用 户 登 录 处 理 程序 
时 ,对 于 用 户 输入 的 密码 , 需 利 用 md5 函数 处 理 后 青 与 会 员 表 中 的 字段 值 比较 是 否 一 致 。 
七 、 设 计 步 又 

1. 设计 用 户 登录 界面 


(1) 新 建 网 页 。 在 “文件 ”面板 中 选择 wssd 为 当前 站 点 , 单 击 “ 文 件 ” 菜 单一 “新 建 ” 选 
项 ,选择 “空白 页 ”,“ 页 面 类 型 "为 PHP,“ 布 局 ”为 无 , 单 击 “ 创 建 "按钮 。 
(2) 编写 代码 。 在 “代码 ”视图 中 ,删除 全 部 源 代码 ,输入 以 下 代码 : 


<Html><Head><Meta CharSet="utf-8" /> 
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<Title> 用 户 登录 </Title></Head> 
<Body> 
<div class="areatitle"> 用 户 登 录 </div> 
<div class="areamain"> 
<formaction="login.act .php" method="POST" name="login"> 
<div class="login"> 
账号 :<input type="text" name="userid" /><br> 
密码 :<input type="password" name="password" /><br> 
<p><input name="sub" type="submit" value=" 登 录 " /></p> 
</div></form></div> 
</Body></Html> 


(3) 保存 文件 。 单 击 “ 文 件 " 菜 单一“ 另存 为 ”选项 ,选择 站 点 wssd 根 目录 ,输入 文件 
名 login. inc. php, 单 击 “ 保 存 ” 按 钮 , 按 F12 在 浏览 器 中 运行 效果 如 图 7-7 所 示 。 


图 7-7 用 户 登 录 表 单 


2. 设计 登录 信息 处 理 程序 


(1) 新 建 网 页 。 在 “文件 "面板 中 设置 “当前 站 点 "为 wssd, 单 击 " 文 件 "菜单 ”新建 ” 
选项 ,选择 “空白 页 ”, “页 面 类 型 "为 PHP,“ 布 局 ”为 无 , 单 击 “ 创 建 "按钮 。 
(2) 编写 代码 。 在 “代码 "视图 中 ,删除 全 部 源 代码 后 ,输入 以 下 代码 : 


<?php 
if(!isset($_SESSION)) 
session start(); 
header ("Content-type: text/html; charset=utf-8"); // 设置 网 页 编码 为 utf-8 
include "connections/wssd.php"; // 包含 连接 配置 文件 
if (empty($_POST["userid"]) || empty($_POST["password"])) 
{ header ("refresh:10;url=http://localhost/wssd"); //10 秒 后 转 到 主页 index .php 
echo "用 户 名 或 密码 不 能 为 空 !1"; } 
else 
{ $userid =$ POST["userid"]; // 获取 会 员 账号 
$password =$_POST["password"]; // 获取 密码 
$password =md5 ($password); // 利用 加 密 函 数 md5 对 密码 加 密 处 理 
$sql ="select * from hyb where 会 员 账号 ='$userid' and 密码 ='$password'"; 
$result =mysql query($sql); 
$num =mysql num rows($result); 


if (empty ($num)) 
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{ header ("refresh:10;url=http://localhost/wssd");//10 秒 后 转 到 主页 index.php 
echo "用 户 名 或 密码 错误 !"; } 
else 
{ $row=mysql fetch assoc($result); 
$username =$row[" 姓 名 "]; ”// 获取 姓名 
$role =$row[" 角 色 "]; // 获取 角色 
$_SESSION["islogin"] =1; // 已 经 登录 
$_SESSION["userid"] =$userid; 
$_SESSION["username"] =$username; 
$_SESSION["role"] =$role; 
header ("refresh:3;url=http://localhost/wssd"); // 3 秒 后 转 到 主页 index.php 
echo $username, "登录 成 功 !"; } 


省 人 


(3) 保存 文件 。 单 击 “ 文 件 "菜单 “另存 为 ”选项 ,选择 站 点 wssd 根 目录 ,输入 文件 
名 login. act. php ,保存 并 关闭 文件 。 


3. 设计 用 户 退出 页 面 


(1) 新 建文 档 。 在 “文件 ”面板 中 设置 “当前 站 点 ”为 wssd, 单 击 * 文 件 ? 菜 单一 "新建 
选项 ,选择 “空白 页 ”,“ 页 面 类 型 "为 PHP,“ 布 局 ”为 无 , 单 击 “ 创 建 "按钮 。 
(2) 编写 代码 。 在 “代码 ”视图 中 ,删除 全 部 源 代码 后 ,输入 如 下 代码 : 


<?php 
if (!isset($_SESSION) ) 
session start(); 


header ("Content-type: text/html; charset=utf-8"); 


$username =$_SESSION ["username"]; // 保留 用 户 名 

session destroy(); // 注销 SESSION 

echo $username . "已 退出 登录 ,3 秒 后 返回 主页 !"; 

header ("refresh:3;url=http://localhost/wssd"); // 跳 转 回 到 网 站 首页 ?> 


(3) 保存 文档 。 单 击 “ 文 件 " 菜 单一“ 另存 为 ”选项 ,选择 站 点 wssd 根 目 录 , 输 入 文件 
名 logout. act. php, 单 击 “ 保 存 ” 按 钮 ,关闭 此 文件 。 

4. 设计 网 站 首页 

(1) 创建 首页 。 在 “文件 ”面板 中 双击 打开 mb. php 文件 , 单 击 “ 文 件 " 菜 单一 “另存 
为 ”选项 ,选择 站 点 根 目录 wssd, 输 入 文件 名 为 index. php, 单 击 “ 保 存 ” 按 钮 。 

(2) 编写 首页 代码 。 在 index. php 的 “代码 ”视图 中 ,将 “模板 ”两 个 字 替 换 为 “网 上 书 
店 ”; 将 “二 div class 一 "areatitle" 二 标题 一 /div 之 ”和 “一 div class 王 "areatable" 二 添加 内 容 
去 /div> "两 行 代码 蔡 换 为 如 下 代码 : 


<?php 
if (!(isset($ SESSION['islogin']) && $ SESSION['islogin'] ==1) ) 
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国 


include('login.inc.php'); // 车 未 登录 则 显示 登录 界面 


else  // 若 已 经 登录 
{ if ($_SESSION[I'role'] == "0') 
{ // 如 果 是 普通 用 户 ?> 


<div class="areatitle"> 欢 迎 <?php echo $ _SESSION ["username"]; 


店 </div> 
<div class="areatable"> 
<div class="link"><ul><!-- 显示 普通 用 户 功能 --> 
<1i><a> 图 书 选 购 </a></1i><1i><a> 订 单 统计 </a></1i> 
<1i class="last"><a> 修 改 密码 </a></1i> 
</ul></div></div> 
<?php 1} 

if ($_SESSION['role'] =="'1') 

{ // 如 果 是 管理 员 ?> 


?> 访问 网 上 书 


<div class="areatitle"> 欢 迎 <?php echo $_SESSION ["username"];?> 管 理 员 < /div> 


<div class="areatable"> 
<div class="link"><ul> <!-- 显示 管理 员 功 能 --> 


<1i><a> 出 版 社 信息 管 理 </a></1i><1i><a> 类 别 信息 管 理 </a></1i> 


<1li class="last"><a> 图 书信 息 管理 </a></1i> 
</ul></div></div> 


<?php }} ?> 


(3) 预览 文件 。 保 存 文件 , 按 F12 预览 效果 如 图 7-4 所 示 。。 


八 、 思 考题 


如 何 利用 “登录 用 户 ” 和 "* 退 出 用 户 ? 服 务 器 行为 设计 用 户 登 录 与 退出 网 页 程序 ? 


7.3 管理 员 数 据 维护 程序 设计 


一 、 实 验 目的 


掌握 Dreamweaver 可 视 化 操作 界面 的 使 用 方法 ,利用 插入 、 更 新 和 删除 记录 服务 器 


行为 ,学 习 设计 操纵 数据 的 PHP 网 页 程序 的 方法 。 


二 、 实 验 任务 


(1) 设计 如 图 7-8 所 示 的 出 版 社 信息 浏览 网 页 glcbsb. php, 网 页 标题 为 管理 出 版 社 


信息 ”, 表 格 标题 为 “出 版 社 信息 管理 ,表格 其 他 参数 采用 系统 默认 配置 。 


(2) 修改 程序 glcbsb. php; 在 表格 的 右 侧 插入 一 列 , 在 标题 行 单元 格 中 输入 “ 操 
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作 1”, 单 元 格 内 容 中 输入 “修改 ”, 并 对 文字 “修改 ”设置 链接 ,能 够 将 当前 行 中 的 出 版 社 编 
码 提交 给 修改 出 版 社 信息 的 网 页 xgcbsb. php, 浏 览 效果 如 图 7-9 所 示 。 


出 版 社 信息 管理 





出 版 社 信 息 管理 

i EF 出 所 入 各 称 。 损人 E1 | 
| 融雪 育 册 岳 社 04 | 高 尖 教 育 出 版 社 公示 
机 轿 工 半 出 上 社 





111 | I | | 
5 Ri 出 社 | | 


| 人 R 电 di 入 
电子 工业 出 版 社 二 | 电子 ktk 版 让 | 名 下 | 
焉 华 大 字 出 所 社 | | 形 举 大字 册 版 社 优 政 | 


esa Bee 
中 国 全 融 出 版 社 | 5049 。 | 中 国 全 融 出 版 社 | 人 让 | 
| 中信 出 所 | “5066 | 中 信 出 版 人 | 外 履 | 











图 7-8 显示 出 版 社 表 中 的 信息 图 7-9 添加 “修改 "操作 


(3) 设计 修改 出 版 社 信息 的 网 页 程序 xgcbsb. php, 网 页 标题 为 “修改 出 版 社 信息 ”， 
在 网 页 主体 中 设计 表单 ,在 出 版 社 表 (cbsb) 中 利用 链接 传递 来 的 出 版 社 编码 搜索 对 应 的 
信息 ,与 表单 中 相应 控件 绑 定 ,以 显示 其 内 容 ; 单 击 表单 中 的 “修改 "按钮 ,通过 “更 新 记录 ” 
服务 器 行为 实现 出 版 社 名 称 的 修改 ,浏览 效果 如 图 7-10 所 示 。 

(4) 修改 网 页 程序 glcbsb. php, 在 表格 的 右 侧 插入 一 列 , 在 标题 单元 格 中 输入 “ 操 
作 2”, 单 元 格 内 容 中 输入 “删除 ”, 并 对 文字 “删除 "设置 链接 ,能 够 将 当前 行 中 的 出 版 社 编 
码 提交 给 删除 信息 的 网 页 程序 sccbsb. php ,浏览 效果 如 图 7-11 所 示 。 


出 版 社 信息 管理 
| 入 纺 机 出 版 名 称 。 提 人 F1 | 得 fF2 
| 高 村 轨 育 出 版 社 出 这 
机械 工 业 出 版 社 
| 人民 地 电 出 版 社 | 


| 电子 工业 出 版 社 | 
青 于 大 字 出 版 社 

















中 国 金 融 出 版 社 
中 信 出 版 社 








图 7-10 修改 出 版 社 信息 的 网 页 图 7-11 添加 “删除 "操作 


(5) 设计 删除 出 版 社 信息 的 网 页 程序 sccbsb. php, 通 过 “更 新 记录 ”服务 器 行为 实现 
出 版 社 记录 的 删除 。 

(6) 设计 新 增 出 版 社 信息 的 网 页 程序 xzcbsb. php, 网 页 标题 为 “新 增 出 版 社 信息 ”, 在 
表单 控件 中 输入 新 信息 , 单 击 “ 新 增 ” 按 钮 实现 信息 插入 ,浏览 效果 如 图 7-12 所 示 。 再 打 
开 glcbsb. php, 在 表格 下 方 新 的 一 行 中 输入 文字 “新 增 ”, 链 接 到 网 页 xzcbsb. php, 修 改 后 
效果 如 图 7-13 所 示 。 
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出 版 社 编码 出 版 社 名 称 
高 等 教育 出 版 社 
机 械 工 业 出 版 社 











人 民 邮 电 出 版 社 





电子 工业 出 版 社 

清华 大 学 出 版 社 

中 国 全 融 出 版 社 
中 信 出 版 社 


新 增 





新 增 





出 版 社 编码 :|5601 





隐隐 | 区 | 区 | 阶 | 共 | 基 | 归 
展 | 导 | 居 | 杂居 | 屡 | 嫩 | 因 


出 版 社 名 称 ， | 吉林 大 学 出 版 社 | 
新 增 




















图 7-12 新 增 出 版 社 页 面 图 7-13 添加 “新 增 " 操 作 


三 、 任务 分 析 


任务 (1) 将 网 页 模板 mb. php 另存 为 网 页 glcbsb. php, 首 先 绑 定 记录 和 集 , 获 取出 版 社 
表 中 的 全 部 记录 ,再 利用 动态 表格 显示 记录 集 内 容 。 

任务 (2) 在 任务 (1) 的 基础 上 ,在 表格 的 最 右 侧 插入 新 列 , 按 要 求 输入 内 容 并 设置 
链接 。 

任务 (3) 将 网 页 模板 mb. php 另存 为 网 页 xgcbsb. php, 接 收 链 接 传递 来 的 出 版 社 编 
码 绑 定 记录 集 , 并 将 记录 集 的 内 容 与 表单 控件 绑 定 , 再 绑 定 “更 新 记录 ”服务 器 行为 实现 信 
息 的 修改 。 任 务 (4) 与 任务 (2) 类 似 。 

任务 (5) 将 网 页 模板 mb. php 另存 为 网 页 sccbsb. php, 绑 定 “ 删 除 记录 ”服务 器 行为 实 
现 信 息 删 除 。 

任务 (6) 在 网 页 xzcbsb. php 中 设计 表单 实现 新 内 容 的 输入 ,再 绑 定 “插入 记录 ”服务 
器 行为 实现 信息 的 插入 。 最 后 修改 网 页 glcbsb. php, 添 加 “新 增 " 链 接 。 


、 预 备 知识 


(1) 绑 定 记录 集 。 单 击 “ 绑 定 ” 面 板 中 的 “十 ”>“ 记 录 集 (查询 )” 选 项 ,进入 “记录 和 集 ” 
对 话 框 ,能 创建 记录 集 ( 对 数据 表 查 询 后 的 结果 集 ) ,如 图 7-14 所 示 。 

(2) 绑 定 服务 器 行为 。 单 击 “ 服 务 器 行为 ”面板 中 的 “十 ”选择 “插入 记录 ”更 新 记 
录 ” 或 “删除 记录 ”选项 ,进入 对 应 的 对 话 框 ,设置 参数 ,实现 相关 操作 。 

(3) 带 参 数 的 链接 。 打 开 和 链接 的 页 面 时 ,通过 链接 参数 能 够 实现 页 面 间 的 数据 传递 ， 
其 语法 格式 为 : “二 A href 二 "url? 变量 名 1 一 值 1& 变量 名 2 王 值 2" 二 链接 内 容 
二 /A 这 ”"。 同 时 可 以 传递 多 个 参数 ;在 链接 网 页 中 通过 PHP 的 超 全 局 数组 $_GET 获取 
参数 值 ,语法 格式 为 $_GET[' 下 标 名 "]。 
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区 一 | 区号] 
记录 集 名 称 名 称 - Recordset1 证 
数据 库 连 接 连接 (eal) | (es 
数据 表 一 |- 雪 格 [出版 请 入 统计 = 
结果 中 的 列 列 : 回信 部 | 日 进 定 的 : ss 
































筛选 条 件 第 迁 无 。 7][= 


结果 排序 ”省 _ = 
条 件 排序 [无 天 

















攻 = J 


图 7-14 绑 定 记 录 集 对 话 框 








五 、 技 能 点 


(1) 绑 定 记 录 集 。 在 “ 绑 定 ”面板 中 实现 。 

(2) 动态 数据 表 设 计 。 通 过 拖 动 的 方式 ,将 记录 集 内 容 设计 在 网 页 中 ; 单 击 “ 插 入 " 菜 
单一 数据 对 象 "~ 动态 数据 ”动态 表格 ”选项 ,也 可 以 在 网 页 中 直接 以 表格 的 形式 插 
人 数据 表 。 

(3) 服务 器 行为 设计 。“ 服 务 器 行为 ”面板 提供 了 多 种 服务 器 行为 ,能 够 实现 插入 、 更 
新 和 删除 记录 等 基本 操作 。 

(4) 表单 控件 的 动态 数据 源 设计 。 选 中 “表单 ”控件 ,在 “属性 ”面板 上 , 单 击 “ 初 始 值 ” 
文本 框 右 侧 的 闪电 按钮 ( 绑 定 动态 源 ) ,在 动态 数据 对 话 框 中 选择 相应 数据 源 即 可 。 


六 、 注 意 事 项 


(1) 通过 拖 动 方式 显示 记录 集中 内 容 时 ,只 能 显示 记录 集中 的 第 一 条 记录 ,需要 绑 定 
“重复 区 域 " 服 务 器 行为 才能 将 记录 集中 的 全 部 记录 显示 出 来 。 

(2) 在 绑 定 “更 新 记录 ”服务 器 行为 时 ,字段 从 表单 控件 获取 数据 ,要 注意 数据 类 型 是 
和 否 与 字段 类 型 匹配 。 


七 、 设 计 步 又 


1. 设计 管理 出 版 社 信息 的 网 页 


(1) 创建 文件 glcbsb. php。 在 “文件 ”面板 中 双击 打开 mb. php 文件 , 单 击 “ 文 件 ” 菜 
单一 “另存 为 选项 ,输入 文件 名 glcbsb. php , 单 击 “保存 "按钮 。 

(2) 修改 内 容 。 在 glcbsb. php 的 “代码 ”视图 中 ,将 “模板 ”两 个 字 替 换 为 “管理 出 版 
社 信息 ” “标题 ”两 个 字 替 换 为 “出 版 社 信息 管理 ”。 
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(3) 绑 定 记录 集 。 在 “ 绑 定 ”面板 中 , 单 击 “ 十 ”>“ 记 录 和 集 (查询 )” 选 项 ,在 “记录 集 ” 对 
话 框 中 输入 “名 称 ”rs_cbsb, 选 择 “ 连 接 ” 为 wssd, “表格 ”为 cbsb,“ 列 ”选择 “全 部 ”, 单 击 
“确定 ”按钮 。 

(4) 在 页 面 中 显示 记录 和 集 。 删 除 “ 添 加 内 容 ”4 个 字 , 单 击 “ 插 入 ”菜单 “数据 对 象 ” 
一 “动态 数据 ”一 "动态 表格 ”选项 ,在 对 话 框 中 设置 记录 集 为 rs_cbsb, 显 示 为 “所 有 记录 ”， 
单 击 “ 确 定 ” 按 钮 。 

(5) 设置 表格 样式 。 在 “设计 ”视图 下 , 单 击 表格 并 在 标签 选择 器 中 选中 二 table 二 标 
签 ,在 “属性 ”面板 中 设置 类 为 tb, 按 Fl2 保存 文件 并 浏览 ,效果 如 图 7-8 所 示 。 关 闭 
glcbsb. php 文件 。 

(6) 在 首页 中 设计 “出 版 社 信息 管理 链接。 在 “文件 "面板 中 双击 打开 index. php 文 
件 , 在 “设计 ”视图 下 ,选中 文字 “出 版 社 信息 管 理 ”, 在 “属性 ”面板 的 “链接 "文本 框 中 输入 
glcbsb. php。 按 F12 键 保存 并 浏览 信息 ,输入 管理 员 用 户 名 及 密码 后 ,在 图 7-6 中 单 击 
“出 版 社 信 息 管理 ”链接 ,浏览 器 操作 区 域 显 示 的 信息 如 图 7-8 所 示 , 最 后 关闭 并 保存 
index. php 文件 。 


2. 设计 修改 信息 的 链接 


(1) 打开 网 页 。 在 “文件 ”面板 中 双击 打开 glcbsb. php 文件 。 

(2) 修改 表格 。 在 “设计 ”视图 下 , 单 击 “ 出 版 社 名 称 ” 单 元 格 , 单 击 “ 插 入 ”菜单 一 “ 表 
格 对 象 "一 "在 右边 插入 列 ? 选 项 ,在 新 列 上 方 单元 格 中 输入 “操作 1”, 下 方 单元 格 中 输入 

(3) 设计 链接 。 在 “代码 ”视图 下 ,将 “修改 "两 个 字 改 为 下 列 代码 : 


<a href= "xgcbsb.php? cbsbm=<?php echo $row_rs_cbsb[' 出 版 社 编码 ']; ?>"> 修 改 < /a> 


(4) 保存 并 预览 。 按 F12 键 ,保存 glcbsb. php, 浏 览 器 操作 区 域 显示 效果 如 图 7-9 
所 示 。 


3. 设计 修改 信息 的 网 页 程序 


(1) 创建 xgcbsb. php。 在 “文件 ?面板 中 双击 打开 mb. php 文件 , 单 击 “ 文 件 "菜单 一 
“另存 为 "选项 ,输入 文件 名 xgcbsb. php , 单 击 “保存 ?按钮 。 

(2) 修改 内 容 。 在 xgcbsb. php 的 “代码 ”视图 中 ,将 “模板 ”两 个 字 替 换 为 “修改 出 版 
社 信息 ”; “标题 ”两 个 字 替 换 为 “修改 ”;“ 二 div class 一 "areatable" 二 添加 内 容 一 /div 过” 改 
为 如 下 代码 : 


<div class="areamain"></div> 


(3) 绑 定 记录 集 。 在 “ 绑 定 ”面板 中 , 单 击 “ 十 ”>“ 记 录 和 集 (查询 )” 选 项 ,在 “记录 集 ” 对 
话 框 中 按 图 7-15 进行 设置 , 单 击 “ 确 定 ” 按 钮 。 

(4) 设计 表单 。 将 光标 定位 在 “二 div class "areamain" 二 ”和 “一 /div 二 ”之 间 ,在 
“设计 ”视图 中 , 单 击 “ 插 入 ”菜单 一 “表单 >“ 表单 ”选项 。 

(5) 创建 表单 控件 。 输 入 “出 版 社 编码 ”, 单 击 “ 插 入 ”一 “表单 ”一 “文本 域 ” 菜 单项 和 
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图 7-15 绑 定 记 录 集 


“确定 ?按钮 ,双击 文本 域 ,在 “属性 ?面板 中 的 “文本 域 "下 方 输入 bm, 选 中 * 只 读 ? 选 项 , 单 
击 “ 初 始 值 ”文本 框 右 侧 的 闪电 按钮 ,在 “动态 数据 "对话 框 中 , 单 击 记 录 集 (rs_xgcbs)" 左 
侧 * 十 ”选中 “出 版 社 编码 ”, 单 击 “ 确 定 ”按钮 。 

(6) 创建 表单 控件 。 在 新 行 上 输入 文字 “出 版 社 名 称 ”, 单 击 “ 插 入 ”一 “表单 ”>“ 文 本 
域 ”菜单 项 和 “确定 ”按钮 ,双击 文本 域 .在 “属性 "面板 中 的 “文本 域 " 输 入 mc, 单 击 “ 初 始 
值 "文本 框 右 侧 的 闪电 按钮 ,在 “动态 数据 ?对 话 框 中 , 单 击 “记录 集 (rs_xgcbs)" 左 侧 “ 十 ”， 
选中 “出 版 社 名称 ”, 单 击 “ 确 定 ” 按 钮 。 

(7) 创建 表单 控件 。 在 新 行 上 单 击 “ 插 入 "菜单 一 “表单 “按钮 "菜单 项 和 “确定 ” 按 
钮 ,在 属性 面板 中 ,设置 值 为 “修改 ”。 

(8) 绑 定 服务 器 行为 。 在 “服务 器 行为 ”面板 中 , 单 击 “ 十 "按钮 ~“ 更 新 记录 ”选项 ,在 
对 话 框 中 按 图 7-16 设置 , 单 击 “确定 ”按钮 。 关 闭 并 保存 文件 。 

















在 更 新 后 , 转 到 :glcbsb. php 浏览 


是 一 一 




















图 7-16 绑 定 “更 新 记录 ”服务 器 行为 


(9) 修改 出 版 社 名 称 。 浏 览 glcbsb. php 网 页 ,在 图 7-9 中 单 击 某 出 版 社 的 “修改 " 链 
接 , 可 以 在 图 7-10 中 修改 该 出 版 社 名 称 。 


4. 设计 删除 信息 的 链接 


(1) 打开 网 页 。 在 “文件 ”面板 中 ,双击 打开 glcbsb. php 文件 。 
(2) 修改 表格 。 在 “设计 ”视图 下 , 单 击 “ 操 作 1” 的 单元 格 , 单 击 “ 插 入 ”菜单 一 “表格 对 
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象 " 一 在 右边 插入 列 ? 选 项, 上方 单元 格 中 输入 "操作 2”, 下方 单 元 格 中 输入 “删除 ”。 
(3) 设计 链接 。 在 “代码 ”视图 下 ,将 “删除 ”两 字 替 换 为 下 列 代码 : 


<a href="sccbsb.php? cbsbm=<?php echo $row_rs_cbsb[' 出 版 社 编码 ']; ?>"> 删 除 < /a> 


(4) 保存 并 预览 。 按 F12 键 ,保存 到 glcbsb. php, 浏 览 器 操作 区 域 显 示 的 效果 如 
图 7-11 所 示 。 


5. 设计 删除 信息 的 网 页 程序 


(1) 新 建 网 页 。 单 击 “ 文 件 "菜单 “新 建 "选项 ,选择 “空白 页 ”,“ 页 面 类 型 "为 PHP， 
“布局 ”为 无 , 单 击 “创建 "按钮 。 

(2) 保存 文件 。 单 击 “ 文 件 " 菜 单一 “保存 ”选项 ,输入 “文件 名 "为 sccbsb. php, 单 击 

(3) 绑 定 服务 器 行为 。 在 “服务 器 行为 ”面板 中 , 单 击 “ 十 ”按钮 “删除 记录 ”选项 , 按 
图 7-17 所 示 的 内 容 设 置 , 单 击 “ 确 定 ” 按 钮 。 


删除 记录 





首先 检查 是 否 已 定义 变量 - | 主键 值 三 
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删除 后 . 持 到 ; glcbsb. php 











图 7-17 做 定 “ 删 除 记录 ”服务 器 行为 
(4) 编辑 代码 。 切 换 到 “代码 ”视图 ,在 下 列 语句: 
$Result1 =mysql_query ($deletesQL, $wssd) or die (mysql error()); 
之 前 插入 下 列 代码 ,保存 并 关闭 文件 。 


$selectSQL ="select * from tsb where 出 版 社 编码 ='" . $_GET['cbsbm'] ."'"; 
$result =mysql query ($selectSQL, $wssd) or die(mysql error()); 
if (mysql_num rows ($result)>0) // 如 果 相关 联 的 tsb 中 存在 对 应 记录 
{ header ("Content-type: text/html; charset=utf-8"); // 设置 网 页 编码 方式 
header ("refresh:3;url=http://localhost/wssd/glcbsb.php"); 
die ("图 书 表 tsb 中 存在 此 出 版 社 的 相关 记录 ,不 能 删除 此 出 版 社 信息 。") ;} 


6. 设计 新 增 信息 的 网 页 


(1) 创建 xzcbsb. php。 在 “文件 ”面板 中 双击 打开 mb. php 文件 , 单 击 “ 文 件 " 菜 单一 
“另存 为 ”, 输 入 文件 名 xzcbsb. php , 单 击 “保存 ”按钮 。 

(2) 修改 内 容 。 在 “代码 "视图 下 ,将 “模板 ”两 个 字 改 为 “新 增 出 版 社 信 息 ”; “标题” 两 
个 字 改 为 “新 增 ”;“ 二 div class 二 "areatable" 放 添加 内 容 过 /div 这 ” 改 为 如 下 代码 : 
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<div class="areamain"></div> 


(3) 设计 表单 。 光 标定 位 “一 div class 王 "areamain" 二 ”和 “一 /div 二 ”之 间 , 在 “ 设 
计 ” 视 图 中 , 单 击 “ 插 入 ”菜单 一 “表单 >“ 表单” 选项 。 

(4) 插入 Div。 单 击 “ 插 入 ”菜单 “布局 对 象 >“Div 标签 "选项 ,在 弹出 的 对 话 框 中 
设置 “类 ”为 login, 单 击 “ 确 定 ” 按 钮 。 

(5) 编写 代码 。 在 “代码 ”视图 下 ,删除 “此 处 显示 class "login" 的 内 容 ”, 重 新 输入 如 
下 代码 : 

出 版 社 编码 :<input type= "text" name="bm" ><br> 

出 版 社 名 称 :<input type= "text" name="mc" ><br> 

<p><input name="sub" type="submit" value=" 新 增 "/>< /p> 

(6) 绑 定 服务 器 行为 。 单 击 "服务 器 行为 "面板 中 的 “十 ”一 “插入 记录 ”选项 ,在 对 话 
框 中 按 图 7-18 设置 , 单 击 “确定 按钮。 保存 并 关闭 文件 。 





提交 值 ， 自 ;| fornl 
连接 : wssd 

















插入 后 ， 转 到 [81cbsb. php 





图 7-18 设置 插入 记录 ”服务 器 行为 
(7) 编辑 代码 。 切 换 到 “代码 "视图 ,在 下 列 语句 : 
$Resultl =mysql query($insertSQL, $wssd) or die (mysql error()); 
之 前 插入 以 下 代码 ,保存 并 关闭 文件 。 


$selectSQL ="select * from cbsb where 出 版 社 编码 ='" . $_POST['bm']."'"; 
$result =mysql query ($selectSQL, $wssd) or die(mysql error()); 
if (mysql_num rows ($result)>0) // 如 果 cbsb 中 已 经 存在 此 编码 
{ header ("Content-type: text/html; charset=utf-8"); // 设置 网 页 编码 方式 
header ("refresh:3;url=http://localhost/wssd/glcbsb.php"); 
die ("出 版 社 表 cbsb 中 已 经 存在 此 出 版 社 编码 ,不 能 插入 此 信息 .") ;} 


(8) 修改 网 页 。 在 “文件 ”面板 中 ,双击 打开 glcbsb. php 文件 。 在 “设计 ”视图 下 ,在 
表格 的 下 方 创建 新 行 ,输入 文字 “新 增 ”, 选 中 此 文字 ,在 属性 面板 的 “链接 ”文本 框 中 输入 
xzcbsb. php 。 

(9) 增加 出 版 社 信息 。 按 F12 键 ,保存 glcbsb. php 并 浏览 网 页 , 单 击 图 7-13 中 的 “新 
增 ” 按 钮 ,在 图 7-12 中 可 以 增加 出 版 社 编码 和 名 称 。 
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八 、 思 考题 
(1) 如 何 编写 PHP 代码 将 记录 集中 的 内 容 全 部 显示 到 表格 中 ? 
(2) 在 修改 和 新 增 信 息 时 ,如 何 对 内 容 进 行 有 效 性 验证 ? 


(3) 在 图 7-6 中 ,为 管理 员 用 户 设计 * 出 版 社 信息 管理 ”链接 及 网 页 外 ,还 需要 设计 哪 
些 链 接 及 网 页 ? 按 本 实验 的 内 容 , 如 何 设计 这 些 网 页 ? 


7.4 普通 用 户 图 书 选 购 页 面 设计 


一 、 实验 目 的 


以 设计 网 上 书店 系统 的 普通 用 户 图 书 选 购 界面 为 例 ,学 会 通过 记录 集 的 绑 定 和 表单 
发 送 数据 的 程序 设计 方法 和 过 程 。 


二 、 实 验 任务 


(1) 设计 图 书 搜索 页 面 tsxg. php, 网 页 标题 为 “图书 选 购 ”, 页 面 标题 为 “图 书 搜索 ”， 
利用 表单 及 其 控件 设置 搜索 条 件 ,包括 图 书 


名 称 、 出 版 社 名 称 、 图 书 类 别 、 著 译 者 .定价 范 ER 
用 和 折扣 率 范 转 , 单 击 " 搜 索 " 按 机 开始 搜索 | 。 egtsr am 一 一 本 
图 书 , 页 面 效 果 如 图 7-19 所 示 。 3 计划 it 疗 

省 


(2) 设计 图 书 搜索 结果 显示 页 面 ssts 
.Php, 网 页 标题 为 “图 书 搜索 结果 ”, 利 用 表格 
将 搜索 到 的 图 书信 息 显示 在 页 面 中 ,并 且 在 
表格 的 最 后 一 列 设置 “购买 "链接 ,链接 到 生 图 7-19 图 书 搜索 页 面 
成 订单 的 网 页 tsdd. php ,并 同时 向 它 发 送 当 
前 图 书 的 书号 ,页面 效果 如 图 7-20 所 示 。 








图 书 搜索 结果 
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图 7-20 图 书 搜索 结果 
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(3) 设计 生成 订单 的 网 页 tsdd. php, 页 面 效果 如 图 7-21 
所 示 ,在 页 面 中 显示 图 书 的 书 名 、 定 价 和 折扣 ,用 户 输入 购买 STR 
册 数 ,选择 是 否 立即 付款 ,并 在 表单 中 设置 3 个 隐藏 域 , 用 以 二 
发 送 图 书 的 书号 、 印 次 和 定价 , 单 击 “ 购 买 ”按钮 将 表单 数据 发 7 
送 到 程序 tsdd. act. php。 [] 

(4) 设计 订单 后 台 处 理 程序 tsdd. act. php, 接 收 网 页 男 721 设置 订单 参数 
tsdd. php 发 送 来 的 数据 。 若 购买 图 书 册 数 空 或 小 于 等 于 0， 
则 订单 失败 ;否则 产生 一 条 新 订单 记录 , 插 到 ygxsb 中 。 


三 任务 分 析 














任务 (1) 在 网 页 中 设计 一 个 表单 ,利用 表单 控件 设置 图 书 搜索 条 件 。 

任务 (2) 利 用 搜索 条 件 生成 一 条 Select 语句 搜索 图 书 ,将 搜索 结果 以 表格 的 形式 显示 
到 页 面 中 。 表 格 最 后 一 列 设 为 “购买 ”链接 ,通过 参数 发 送 当 前 图 书号 。 

任务 (3) 利 用 表单 ,显示 图 书 的 基本 信息 ,实现 购买 册 数 和 是 否 付 款 的 参数 设置 ,并 在 
表单 中 创建 隐藏 域 ,向 后 台 处 理 程序 发 送 更 多 的 参数 。 

任务 (4) 根 据 接收 到 的 参数 设计 一 条 Insert 语句 ,发 送 此 语句 生成 订单 。 


四 、 预 备 知识 


(1) $_GET 超 全 局 数组 。 利 用 带 参 数 的 链接 传递 数据 时 ,在 链接 页 面 中 使 用 PHP 
的 超 全 局 数组 $_GET 获取 数据 ,语法 格式 为 $_GET[ 数 组 下 标 ]。 

(2) 表单 中 的 隐藏 域 。 隐 藏 域 在 页 面 中 对 于 用 户 是 不 可 见 的 ,在 表单 中 插入 隐藏 域 
的 目的 在 于 收集 或 发 送信 息 , 这 些 信 息 能 够 被 处 理 表单 的 程序 所 引用 ,浏览 者 单 击 “ 发 送 ” 
按钮 时 ,隐藏 域 的 信息 也 同时 发 送 给 服务 器 。 单 击 “ 插 入 ”菜单 “表单 >“ 隐藏 域 ” 选 项 ， 
可 在 页 面 中 插入 隐藏 域 ,其 语法 为 : 


<input type="hidden" name=" 对 象 名 " value=" 值 "> 
五 、 技 能 点 

(1) 表单 中 的 隐藏 域 。 单 击 “ 插 入 "菜单 一 “表单 ”>“ 隐 藏 域 ”选项 ,可 在 页 面 中 插入 
隐藏 域 。 


(2) 表单 中 使 用 列表 控件 。 单 击 “ 插 入 ”菜单 一 “表单 >“ 选择 (列表 /菜单 )” 选 项 ,可 
在 表单 中 插入 列表 控件 。 


六 、 注 意 事 项 


(1) 在 使 用 带 参 数 的 链接 时 ,“? ”与 变量 名 之 间 不 能 有 空格 。 
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(2) 在 设计 图 书 搜索 页 面 的 步骤 (7) 和 步骤 (8) 中 ,为 控件 添加 静态 选项 时 ,选项 的 值 
为 空 ,标签 为 “全 部 ”。 


七 、 设 计 步 又 


1. 设计 图 书 搜索 页 面 


(1) 打开 并 另存 网 页 。 在 "文件 "面板 中 ,双击 打开 mb. php 文件 , 单 击 * 文 件 "菜单 一 
“另存 为 "选项 ,输入 文件 名 tsxg. php, 单 击 “ 保 存 "按钮 。 

(2) 修改 内 容 。 在 “代码 "视图 下 ,将 “模板 "两 字 改 为 "图 书 选 购 ”;“ 标 题 "两 字 改 为 
“图 书 搜索 ”。 

(3) 绑 定 记录 集 cbsb。 在 “设计 "视图 下 , 单 击 绑 定 面板 中 的 “十 ”~“ 记 录 集 (查询 )” 
选项 ,在 “记录 集 ? 对 话 框 中 ,设置 “记录 集 名 称 " 为 cbsb, 连 接 " 为 wssd,* 表 格 "为 cbsb， 
“ 列 " 为 全 部 ,筛选 "和 "排序 " 均 为 无 , 单 击 * 确 定 "按钮 。 

(4) 绑 定 记录 集 Ibb。 重 复 步骤 (3) ,在 * 记 录 集 "对 话 框 中 ,设置 “记录 集 名 称 " 为 
lbb,“ 连 接 " 为 wssd,“ 表 格 ” 为 1bb, 单 击 "确定 ”按钮 。 

(5) 设计 表单 。 删 除 “添加 内 容 "4 个 字 , 单 击 "插入 "菜单 一 “表单 "一 "表单 ”选项 。 

(6) 创建 表单 控件 。 在 表单 中 输入 “图 书 名 称 ”, 单 击 “ 持 入 ”菜单 一 “表单 ”一 “文本 
域 "选项 和 * 确 定 "按钮 。 双 击 此 文本 域 ,在 "属性 “面板 中 的 "文本 域 "文本 框 内 输入 tsme。 

(7) 创建 表单 控件 。 在 新 的 一 行 中 输入 “出 版 社 名 称 ”, 单 击 “ 插 入 ”一 “ 表 单 ”~" 选 择 
(列表 /菜单 )" 菜 单项 和 “确定 "按钮 。 双 击 此 控件 ,在 “属性 "面板 中 的 “选择 "文本 框 内 输 
入 cbsme。 单 击 * 动 态 "按钮 ,在 “动态 列表 /菜单 对话 框 中 , 单 击 “静态 选项 "后 的 “十 ” 按 
钮 , 按 图 7-22 设置 相关 参数 ,最 后 单 击 "确定" 按钮 。 
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图 7-22 设置 “出 版 社 名 称 ” 的 列表 值 


(8) 创建 表单 控件 。 在 新 的 一 行 中 输入 “图 书 类 别 ”, 单 击 * 插 入 ”一 “表单 "一 “选择 
(列表 /菜单 ) "菜单 项 和 ”确定 ?按钮 。 双 击 此 控件 ,在 “属性 ?面板 中 的 “选择 "文本 框 内 输 
入 tslb。 单 击 “ 动 态 ” 按 钮 ,在 “动态 列表 /菜单 ”对 话 框 中 , 单 击 “ 静 态 选 项 ”后 的 “十 ”按钮 ， 
按 图 7-23 设置 相关 参数 ,最 后 单 击 “ 确 定 ” 按 钮 。 
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图 7-23 设置 “图 书 类 别 " 的 列表 值 


(9) 创建 表单 控件 。 在 新 的 一 行 中 输入 “ 著 译 者 ”, 单 击 “ 插 入 ”一 “表单 ”一 “文本 域 ” 
菜单 项 和 “确定 ”按钮 。 双 击 此 文本 域 ,在 “属性 ”面板 中 的 “文本 域 " 内 输入 zyz。 

(10) 创建 表单 控件 。 在 新 的 一 行 中 输入 “定价 ”, 单 击 “ 插 入 ”一 “表单 ”一 “文本 域 " 菜 
单项 和 “确定 按钮。 双击 此 文本 域 ,在 “属性 ”面板 中 的 “文本 域 ” 内 输入 zddj。 在 文本 域 
后 接着 输入 “--”, 单 击 “ 插 入 ”一 “表单 >“ 文本 域 ”菜单 项 和 “确定 ”按钮 。 双 击 此 文本 域 ， 
在 “属性 ?面板 中 的 “文本 域 " 内 输入 zgdj。 

(11) 创建 表单 控件 。 在 新 的 一 行 中 输入 “折扣 率 ”, 单 击 “ 插 入 ”一 “表单 ”一 “文本 域 ” 
菜单 项 和 "确定 ?按钮 。 双 击 此 文本 域 ,在 “属性 ?面板 中 的 “文本 域 " 内 输入 zdzk。 在 文本 
域 后 接着 输入 “--”, 单 击 “ 插 入 ”一 “表单 ”>“ 文 本 域 ”菜单 项 和 “确定 按钮。 双击 此 文本 
域 ,在 “属性 ?面板 中 的 “文本 域 " 内 输入 zgzk。 

(12) 创建 表单 控件 。 在 新 的 一 行 中 单 击 “ 插 入 ”一 “表单 >“ 按钮 "菜单 项 和 “确定 ” 
按钮 。 双 击 此 按钮 ,在 “属性 ”面板 中 的 “ 值 ” 文 本 框 内 输入 “搜索 ”。 

(13) 设置 表单 属性 。 在 标签 选择 器 中 单 击 “二 form> ”标签 ,在 “属性 ?面板 的 “动作 ” 
文本 框 内 输入 ssts. php。 

(14) 预览 文件 。 按 F12 键 ,保存 文件 ,预览 效果 如 图 7-19 所 示 。 


2. 设计 图 书 搜索 结果 显示 页 面 


(1) 打开 并 另存 网 页 。 在 “文件 ”面板 中 双击 打开 mb. php 文件 , 单 击 “ 文 件 " 菜 单一 
“另存 为 ”选项 ,输入 文件 名 ssts. php: 单 击 “ 保 存 ” 按 钮 。 

(2) 修改 内 容 。 在 “代码 ”视图 下 ,将 “模板 ”和 “标题 "文字 均 改 为 “图 书 搜索 结果 ”。 

(3) 编写 搜索 代码 。 将 “添加 内 容 ”4 个 字 替 换 为 如 下 代码 : 

<?php 


include ("connections/wssd.php"); // 包含 连接 文件 
$sql ="Select * Fromtsb Where 1 "; 





if($_POsST['tsmc'] !="") // 若 输入 了 图 书 名 称 , 则 与 字段 “ 书 名 ”进行 模糊 匹配 
$sql =$sql . " and 书 名 like '%" . $ POSTI'tame")] 。 "SS" ™y 

if($_ POST['cbsmc'] !="") 
$sql =$sql . " and 出 版 社 编码 ='" . $_POST['cbsmc'] ."'"; 


第 7 单元 动态 网 页 程序 设计 


if($_POST['tslb'] !="") 
$sql =$sql ." and 类 别 编码 = '".$ PosT['tslb'] ."'"; 

if($_POST['zyz'] !="") // 若 输 入 了 著 译 者 , 则 与 字段 “ 著 译 者 ”进行 模糊 匹配 
$sql =$sql . " and 著 译 者 like '%" .$ POST['zyz'] . "S$'"; 

if($ POST['zddj'] !="") // 设置 定价 区 间 
$sql =$sql . "and 定价 >=" .$_POST['zddj'] ; 

if($_POST['zgdj'] !="") 
$sql =$sql . "and 定价 <=" .$_POST['zgdj'] ; 

if($_POST['zdzk'] !="") // 设置 折扣 率 的 区 间 
$sql =$sql . "and 折扣 率 >=" .$_POST['zdzk'] ; 

if($_POST['zgzk'] !="") 








$sql =$sql . " and 折扣 率 <=" . $_POST['zgzk'] ; 
$result =mysql query ($sql) or die(mysql error()); // 发 送 查 询 语句 


$row result =mysql fetch assoc($result); ?> 
(4) 将 搜索 结果 输出 到 网 页 。 在 上 述 代 码 之 后 输入 以 下 代码 : 


<?php 
if ($row result==NULL) // 搜索 结果 为 空 
{ echo "<br> 没 有 找到 符合 条 件 的 图 书 , 请 重新 搜索 "7 
header ("refresh:10;url=http://localhost/wssd/tsxg.php"); // 10 秒 后 转 搜 索 页 
} 
else 
{?> 
<table class="tb"> 
<tr><?php 
foreach ($row result as $key =>$value) 


echo "<th>$key </th>"; // 循环 输出 搜索 结果 中 的 每 一 个 字段 名 


?> 
<th> 操 作 </th>< /tr> 
<?php do { $shh =$row result[' 书 号 ']; // 保存 当前 书号 
?2% 
<tr><?php 
foreach ($row result as $value) 
echo "<td>$value </td>"; // 循环 输出 搜索 结果 中 一 行 中 的 每 列 数据 
?> 


<!-- 带 参数 的 链接 ,将 $shh( 书 号 ) 传 递 到 链接 网 页 --> 
<td><a href="tsdd.php?tsbh=<?php echo $shh; ?>"> 购 买 </a></td></tr> 
<?php } while ($row result =mysql fetch assoc($result)); ?> 
</table> 
<?php |} 


和 


(5) 保存 文件 。 按 Ctrl 十 S 键 ,保存 ssts. php 文件 。 
(6) 浏览 tsxg. php。 在 图 7-19 中 输入 或 选择 相关 关键 字 , 如 图 书 名称 为 “计算 机 ”， 
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单 击 “ 搜 索 ” 按 钮 ,浏览 器 操作 区 域 显示 的 效果 如 图 7-20 所 示 。 
3. 设计 订单 参数 的 网 页 


01) 打开 并 另存 网 页 。 在 "文件 "面板 中 双击 打开 mb. php 文件 , 单 击 "文件 "菜单 一 
“另存 为 "选项 ,输入 文件 名 tsdd. php, 单 击 "保存 "按钮 。 

(2) 修改 网 页 标题 。 在 “代码 "视图 下 ,将 “模板 "两 字 改 为 "图 书 购买 “标题 "两 字 改 
为 "购买 图 书 "。 

(3) 绑 定 记录 集 。 在 绑 定 面板 中 , 单 击 * 十 "~“ 记 录 集 ( 查 询 )" 选 项 ,在 “记录 集 " 对 话 
框 中 按 图 7-24 设置 参数 , 单 击 * 确 定 "按钮 。 




















全 区 ssts 
连接 : |wssd =| [定义 
测试 
表格 |tsb 
殊 回 全 部 “个 先 证 的 : 
Es: 
各 国 
村 : 
mt BEE 
VBL 杀 雪 | tsbh 
排序 ;| 无 加 | 升序 



































图 7-24 绑 定 记 录 集 


(4) 设计 表单 。 删 除 “ 添 加 内 容 ”4 个 字 , 单 击 “ 插 入 "菜单 一 “表单 ”一 “表单 ”选项 , 设 
置 “操作 ”为 tsdd. act. php ,“ 方 法 ”为 post, 单 击 “ 确 定 ” 按 钮 。 
(5) 输出 图 书信 息 。 在 代码 二 /form 二 之 前 插入 以 下 代码 : 


<?php 
echo "<p>". $row_ssts[' 书 名 '] “<p> // 显示 书 名 
echo "<p> 定 价 :" . $row_ssts[' 定 价 '] . "</p>"; // 显示 定价 


echo "<p> 折 扣 :" . $row_ssts[' 折 扣 率 ']/100 . "</p>"; // 显示 折扣 ?> 


(6) 创建 文本 域 。 在 “设计 ”视图 下 ,在 表单 中 新 的 一 行 上 输入 “购买 册 数 ”, 单 击 “ 插 
入 "一 "表单 "文本 域 "菜单 项 和 “确定 "按钮 。 双 击 文本 域 ,在 “属性 "面板 中 的 “文本 域 ” 
内 输入 cs。 

(7) 创建 列表 。 在 新 行 中 输入 “是 否 付款 ”, 单 击 [ 却 a 
“插入 ”一 "表单 ”一 “选择 (列表 /菜单 ," 麻 单项 和 * 确 | ”。 电 呈 ”i 
定 "按钮 。 双 击 此 控件 ,在 “属性 "面板 中 的 “选择 "文本 | [ni 。 | | 三 有 
框 内 输入 未 。 单 击 * 列 表 值 "按钮 , 按 图 7-25 进行 设 | 对 
置 , 单 击 * 确 定 " 按 乌 。 

(8) 创建 隐藏 域 。 在 新 的 一 行 上 单 击 "插入" 菜单 一 -一 
“表单 ”一 “隐藏 域 "选项 ,双击 此 控件 ,在 “属性 ”面板 ”图 7-25 设置 是 否 付款 "的 列表 什 
































必 助 只 
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中 ”隐藏 区域" 下 方 的 文本 框 内 输入 sh, 单 击 “ 值 ”文本 框 右 侧 的 闪电 按钮 ( 绑 定 到 动态 
源 ) ,在 “动态 数据 "对话 框 中 单 击 " 十 ”, 选 中 “书号 ”, 单 击 “ 确 定 ” 按 钮 。 

(9) 创建 隐藏 域 。 重 复 步骤 (8), 再 创建 两 个 隐藏 域 , 分 别 在 “隐藏 区 域 " 下 方 的 文本 
框 内 输入 yc 和 dj , 单 击 * 值 ”文本 框 右 侧 的 闪电 按钮 ,分 别 为 其 绑 定 记录 集中 的 “ 印 次 ”和 
“定价 字段。 

(10) 创建 按钮 。 在 新 行 上 单 击 * 插 和 人 ”~ 表单 ”按钮 ?菜单 项 和 ”确定 ”按钮 ,在 
“属性 ?面板 中 ,设置 值 为 “购买 ”。 关 闭 并 保存 文件 。 

(11) 购买 图 书 。 浏 览 tsxg. php ,在 图 7-19 中 输入 或 选择 相关 关键 字 , 如 图 书 名 称 为 
“计算 机 ”, 单 击 “ 搜 索 ” 按 钮 。 在 图 7-20 中 单 击 某 图 书 行 的 “购买 链接 , 显示 信息 如 
图 7-21 所 示 。 


4. 设计 处 理 订单 数据 的 网 页 程序 


(1) 新 建文 档 。 单 击 “ 文 件 "菜单 一 “新建”" 选 项 ,选择 “空白 页 ”", “页面 类 型 "为 PHP， 
“布局 ”为 无 , 单 击 “创建 "按钮 。 
(2) 编写 代码 。 在 “代码 ”视图 下 ,在 原 有 代码 的 最 后 输入 以 下 代码 : 


<?php 
if (!isset($ SESSION)) session start(); 
include "connections/wssd.php"; // 包含 连接 文件 
if(empty($ POST['cs']) || $_ POST['cs']<=0) 
{ ”// 若 购 买 册 数 为 空 或 小 于 等 于 0 
header ("refresh:10;url=http://localhost/wssd/tsxg.php"); 
echo ' 购 买 册 数 不 能 为 空 值 或 负数 !'; } 
else 
{ $sh=$ POST['sh']; 
$yc=$_POST['yc']; 
$cs=$ POST['cs']; 
$dj =$_POST['dj']; 
$id=$_SESSION['userid']; 
$fk=$ POST['fk']; 
// 设计 insert 语句 ,其 中 书号 、 印 次 和 会 员 账 号 是 文本 型 ,因此 用 单 引号 括 起 来 
$sql ="insert into ygxsb values (default, '$sh', '$yc', curdate(), $cs, 
$dj, '$id', $fk, default)"; 
if( mysql query($sql, $wssd) !=false ) 
{ // 若 成 功 执行 insert 语句 
header ("refresh:3;url=http://localhost/wssd"); 
echo ' 图 书 购 买 成 功 , 三 秒 后 自动 跳 转 到 主页 !'; } 
else 
{ // 车 执行 insert 语句 出 错 
header ("refresh:10;url=http://localhost/wssd"); 
echo “' 图 书 购买 失败 ,10 秒 后 自动 跳 转 到 主页 !'; } 


| 
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(3) 保存 文件 。 单 击 “ 文 件 " 菜 单一 “另存 为 ”选项 ,输入 文件 名 tsdd. act. php, 单 击 
“保存 ”按钮 。 

(4) 设计 “图 书 选 购 ” 链 接 。 在 “文件 ”面板 中 双击 index. php 文件 ,在 “设计 ”视图 下 ， 
选中 文字 “图 书 选 购 ”, 在 “属性 ”面板 的 “链接 ”文本 框 中 输入 tsxg. php。 按 F12 键 保存 并 
浏览 信息 ,输入 普通 用 户 名 及 密码 后 ,在 图 7-5 中 单 击 “图 书 选 购 " 链 接 , 浏 览 器 操作 区 域 
显示 的 信息 如 图 7-19 所 示 , 随 后 可 以 搜索 和 选 购 图 书 。 


八 、 思 考题 
(1) 在 Dreamweaver 中 如 何 绑 定 复杂 的 记录 集 ? 


(2) 如 何 将 多 个 搜索 结果 显示 到 网 页 中 ? 
(3) 在 任务 (3) 中 除了 隐藏 域外 ,还 能 通过 什么 方法 向 后 台 处 理 网 页 发 送 数 据 ? 


7.5 ”普通 用 户 订单 管理 页 面 设计 


一 、 实 验 目 的 

以 Dreamweaver 为 开发 工具 ,通过 可 视 化 设计 环境 ,学 会 利用 HTML 链接 传递 多 个 
数据 的 方法 ,掌握 访问 MySQL 数据 库 的 程序 设计 过 程 。 
二 、 实验 任 务 


(1) 设计 订单 管理 页 面 ddgl. php。 网 页 标题 是 “订单 管理 ”, 利 用 当前 用 户 的 账号 ( 记 
录 在 $_SESSIONLuserid] 中 ) 搜 索 对 应 的 订单 ,使 用 动态 表格 将 搜索 结果 显示 在 网 页 中 ， 
页 面 如 图 7-26 所 示 。 


张波 的 订单 统计 











WS | 书号 | 印 次 预 的 日 期 | 册 数 售 价 ， 会 员 账号 “| 付款 标记 | 目前 状态 
11 | 978-7-111-38074-0 | 1 | 2016-01-20 | 15 | 99.0 | 2201040002 | 已 付 | 取消 
12 |978-7-5049-6590-5 | 1 |2016-01-22| 3 |59.0 | 2201040002 | 已 付 ，| 在 途 





26 |978-7-04-044295-3 | 1 | 2018-06-02 | 3 | 50.0 2201040002 | 未 付 未 发 送 





图 7-26 订单 管理 页 面 


(2) 修改 订单 管理 页 面 ddgl. php。 在 动态 表格 的 右 侧 增加 3 列 , 分 别 设置 付款 .取消 
和 删除 三 个 操作 ,利用 链接 将 当前 图 书 的 书号 和 操作 类 型 (1- 付 款 ,2- 取 消 ,3- 删 除 ) 发 送 到 
后 台 处 理 网 页 程序 ,页 面 效 果 如 图 7-27 所 示 。 

(3) 设计 修改 订单 信息 的 后 台 处 理 程序 ddgl. act. php。 根 据 链 接 发 送 来 的 书号 和 操 
作 类 型 对 预购 销售 表 (ygxsb) 中 的 相关 订单 进行 修改 。 
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预购 单 号 书号 是 入 | 预购 日 期 | 册 数 | 千 价 | 会 员 账号 | 付 雪 标记 | 目前 状态 | 操作 1 | 操作 2 | 操作 3 
1 978-7-111-38074-0 | 1 | 201601-20 | 15 | 99.0 | 2201040002 | Bf 取消 超 省 | 了 
12 |978-7-5049-6590-5 | 1 |2015-01-22 | 3 | 59.0 | 2201040002 | 已 付 取消 | 亿 数 取消 | 出 除 
26 978-7-04-044295-3 | 1 | 2018-06-02 | 3 | 50.0 | 2201040002 | 未 付 未 发 送 | 人 获取 省 | 删除 











7-27 为 订单 管理 网 页 增加 操作 


三 s 任务 分 析 


任务 (1) 利 用 SESSION 记录 的 当前 用 户 账号 绑 定 记录 集 , 并 将 记录 集 以 动态 表格 的 


形式 显示 在 网 页 中 。 


任务 (2) 对 任务 (1) 设 计 的 网 页 进行 修改 ,在 表格 右 侧 增加 3 列 , 输 入 3 种 操作 ,并 设 


计 链 接 发 送 当前 书号 和 操作 类 型 。 


任务 (3) 通 过 接收 到 的 数据 进行 相应 的 处 理 。 


四 、 预 备 知识 


在 页 面 中 显示 记录 集 。 单 击 * 插 和 ”一 “数据 对 象 "一 "动态 数据 ”一 "动态 表格 "菜单 ， 
在 图 7-28 所 示 的 对 话 框 中 设置 参数 , 单 击 “ 确 定 ” 按 钮 ,能 够 将 记录 和 集 以 表格 的 形式 显示 


在 网 页 中 。 


动态 表格 





记录 集 - |Recordsetl 下 





里 示 : 加 


边框 - 1 
单元 格 边 距 1 
单元 格 间距 - 0 








了 
EE 


10 ”记录 
所 有 记录 











五 、 设 计 步 又 
1. 设计 用 户 订单 统计 页 面 
(1) 打开 并 保存 网 页 。 


图 7-28 插入 动态 表格 


“另存 为 "选项 ,输入 文件 名 ddgl. php, 单 击 “ 保 存 " 按 钮 。 
(2) 修改 网 页 标题 。 在 “代码 "视图 下 ,将 “模板 ”两 字 改 为 “订单 管理 ”; “标题 "两 字 改 
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双击 打开 “文件 ”面板 中 的 mb. php 文件 , 单 击 “文件 ?菜单 一 


为 如 下 代码 : 
<?php echo $_SESSION['username']; ?> 的 订单 统计 


(3) 绑 定 记录 集 。 在 “ 绑 定 ?面板 中 , 单 击 “ 十 ”一 “记录 集 ( 查 询 ) ”选项 ,在 “记录 集 ? 对 
话 框 中 按 图 7-29 设置 ,再 单 击 * 确 定 "按钮 。 
















































































记录 集 本 司 [Ex] 
名 称 rs_ddtj | 上 
连接 : [wssd -|[ 定 多 | 了 
要 格 : |yaxsb 了 -一 
太 了 选 定 的 = 
国 
册 数 3 
第 选 . | 会 员 账 号 ||= = 
输入 的 值 | “.$_SESSION[ userid]. 
排序 :| 无 四 | 升序 
4 




















图 7-29 绑 定 记录 集 
(4) 启动 SESSION。 将 第 一 行 代码 ， 
"<?php require once ('Connections/wssd.php '); ?>" 
替换 为 下 列 代码 ， 


<?php 
if(!isset($_ SESSION)) session start (); 
require once('Connections/wssd.php'); 
?> 


(5) 在 页 面 中 显示 记录 集 。 在 “设计 ”视图 下 ,删除 “添加 内 容 ”4 个 字 , 单 击 “ 插 入 ” 菜 
单 ~“ 数 据 对 象 >“ 动 态 数据 ”一 “动态 表格 "选项 ,在 对 话 框 中 设置 记录 集 为 rs_ddtj, 显 
示 为 “所 有 记录 ”, 单 击 “确定 ”按钮 。 

(6) 修改 显示 效果 。 在 “代码 ”视图 下 ,将 下 列 两 行 代码 : 


<td><?php echo $row_rs_ddtj[' 付 款 标记 ']; ?></td> 
<td><?php echo $row rs ddtj["' 目前 状态 ']; ?></td> 





替换 如 下 代码 : 
<td><?php if ($row_rs_ddtj[' 付 款 标记 ']) echo "已 付 "; else echo "未 付 "; ?></td> 
<td><?php if($row_rs_ddtj[' 目 前 状态 ']=='0') echo "未 发 送 " ， 
if($row_rs_ddtj[' 目 前 状态 '] 1') echo "取消 " ; 
if($row_ rs _dqtj['" 目 前 状态 ']= echo "在 途 " ; 
if($row_rs_qddtj[' 目 前 状态 '] 31) echo "签收 " ; 


?></td> 





if($row_ rs _dqtj['" 目 前 状态 ']=='47) 


echo "退货 " ; 
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(7) 设置 表格 样式 。 在 “设计 ”视图 下 ,选中 “标签 选择 器 ”中 的 二 table 放 标签 ,在 “ 属 
性 ”面板 中 设置 类 为 tb, 关 闭 并 保存 文件 。 

(8) 设计 “订单 统计 ”链接 。 在 “文件 ”面板 中 双击 index. php, 在 “设计 ”视图 下 ,选中 
文字 “订单 统计 ”, 在 “属性 ”面板 的 “链接 "文本 框 中 输入 ddgl. php。 按 F12 键 保 存 并 浏览 
信息 ,输入 普通 用 户 名 及 密码 后 ,在 图 7-5 中 单 击 “ 订 单 统计 ”链接 ,浏览 器 操作 区 域 显示 
的 信息 如 图 7-26 所 示 。 


2. 设计 更 改 订单 状态 的 链接 


(1) 打开 订单 管理 网 页 。 在 “文件 ”面板 中 双击 ddgl. php 文件 。 

(2) 修改 代码 。 在 “代码 ?视图 下 ,将 代码 “<?php do { ?>? 改 为 

<?php do { $ygdh =$row rs_dqdtj[' 预 购 单 号 ']; ?> 

(3) 修改 动态 表格 。 在 “设计 ”视图 下 , 单 击 “ 目 前 状态 ”单元 格 和 “插入 ”菜单 一 “表格 
对 象 " 一 “在 右边 插入 列 ?选项 ,在 新 列 上 方 单元 格 中 输入 “操作 1”, 下 方 单元 格 中 输入 “ 付 
款 ”。 同 样 再 插入 2 个 新 列 , 上 方 单元 格 内 容 分 别 输入 “操作 2" 和 "操作 3”, 下 方 单元 格 内 
容 分 别 输入 “取消 ”和 “删除 ”。 

(4) 设计 链接 。 

Q@ 选中 文字 “付款 ”, 在 “属性 ”面板 中 的 “链接 "文本 框 内 输入 : 


ddgl .act.php?ygdh=<?php echo $ygdh; ?>&cz=1 

@ 选中 文字 取消”, 在 “属性 ”面板 中 的 “链接 "文本 框 内 输入 : 
ddgl .act.php?ygdh=<?php echo $ygdh; ? >&cz=2 

@ 选中 文字 “删除 ”, 在 “属性 ”面板 中 的 “链接 "文本 框 内 输入 : 
ddgl .act.php?ygdh=<? php echo $ygdh; ?>&cz=3 

(5) 保存 文件 。 单 击 “ 文 件 "菜单 一 “保存 "选项 ,关闭 文件 。 

3. 设计 更 改 订单 状态 的 网 页 程序 


(1) 新 建 网 页 。 单 击 “ 文 件 "菜单 “新建 "选项 ,选择 “空白 页 ”,“ 页 面 类 型 "为 PHP， 
“布局 ”为 无 , 单 击 “ 创 建 " 按 钮 。 
(2) 编写 代码 。 在 “代码 "视图 下 , 原 有 代码 的 最 后 添加 以 下 代码 : 


<?php 
include "connections/wssd.php"; 
$ygdh =$_GET['ygdh']; 
if($_GET['cz']==1)  // cz 为 1 表示 付款 
$sql ="Update ygxsb set 付款 标记 =1 where 预购 单 号 =$ ygdh"; 
if($_GET['cz']==2)  // cz 为 2 表示 取消 订单 
$sql ="Update ygxsb set 目前 状态 = '1' where 预购 单 号 =$ ygdh"; 
if($_GET['cz']==3)  // cz 为 3 表示 删除 订单 
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$sql = "delete from ygxsb where 预购 单 号 =$ ygdh"; 
if(mysql query ($sql, $wssd) !=false) 
{ header ("refresh:5;url=http://localhost/wssd/ddg]l .php"); 
echo “' 操 作成 功 ,5 秒 后 自动 跳 转 到 订单 管理 页 面 !'; } 
else 
{ header("refresh:10;url=http://localhost/wssd/ddgl .php"); 
echo ' 操 作 失 败 ,10 秒 后 自动 跳 转 到 订单 管理 页 面 !'; } ?> 
(3) 保存 文件 。 单 击 “ 文 件 " 菜 单一 “另存 为 ”选项 ,文件 名 为 ddgl. act. php, 单 击 “ 保 
存 ” 按 钮 。 
(4) 订单 的 付款 、 取 消 和 删除 操作 。 在 “文件 "面板 中 双击 打开 index. php, 按 F12 键 
浏览 信息 ,输入 普通 用 户 名 及 密码 后 ,在 图 7-5 中 单 击 “订单 统计 ”链接 ,浏览 器 操作 区 域 
显示 的 信息 如 图 7-27 所 示 , 可 以 进一步 操作 订单 的 付款 、 取 消 和 删除 链接 。 


六 、 思 考题 


在 模板 文件 mb. php 中 已 经 启动 了 SESSION ,为 什么 任务 (1) 中 还 要 有 步骤 (4) 的 操 
作 ? 是 否 是 多 余 的 ? 


7.6 普通 用 户 修 改 密码 页 面 设计 
一 、 实 验 目 的 
学 习 设计 用 户 修改 密码 的 网 页 。 
二 、 实验 任 务 


(1) 设计 修改 密码 的 网 页 xgmm. php ,网 页 标题 为 “修改 密码 ”, 页 面 中 利用 文本 域 输 
入 原 密码 .新 密码 和 新 密码 确认 , 单 击 * 修 改 " 按 钮 提交 表单 
中 的 数据 ,页 面 效 果 如 图 7-30 所 示 。 

(2) 设计 更 新 密码 的 网 页 程序 xgmm. act. php, 原 密码 、 
新 密码 和 新 密码 确认 均 不 能 为 空 ; 若 原 密码 不 正确 或 新 密码 
与 新 密码 确认 不 一 致 则 修改 失败 。 


三 、 任务 分 析 


任务 (1) 利 用 表单 及 控件 实现 设计 。 
任务 (2) 由 程序 xgmm. act. php 验证 接收 的 数据 ,通过 验证 才能 修改 密码 。 








图 7-30 “修改 密码 "页 面 
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四 、 注 意 事项 


由 于 会 员 表 (hyb) 中 的 密码 字段 保存 加 密 后 的 信息 ,因此 在 比较 用 户 密码 时 ,要 调用 
md5 函数 。 


五 、 设 计 步 又 
1. 设计 修改 密码 的 网 页 


(1) 打开 并 保存 网 页 。 在 “文件 ”面板 中 双击 mb. php 文件 , 单 击 “ 文 件 ” 一 另存 为 
菜单 项 ,输入 文件 名 xgmm. php ,保存 并 关闭 文件 。 

(2) 修改 内 容 。 在 “代码 ”视图 下 ,将 文字 “模板 "和 “标题 " 均 改 为 “修改 密码 ”;“ 二 div 
class 二 "areatable" 志 添加 内 容 二 /div 二 ” 改 为 下 列 代码 : 


<div class="areamain"></div> 


(3) 设计 表单 。 光 标定 位 在 “一 div class 王 "areamain" 之 ”与 “一 /div 之 ”之 间 , 单 击 “ 插 
入 ”菜单 一 “表单 ”一 “表单 ”选项 ,在 对 话 框 中 设置 “操作 ”为 xgmm. act. php,“ 方 法 ”为 
post, 单 击 “ 确 定 ” 按 钮 。 

(4) 插入 Div。 单 击 “ 插 入 "菜单 一 “布局 对 象 >“Div 标签 "选项 ,在 弹出 的 对 话 框 中 
设置 “类 ”为 login, 单 击 “ 确 定 ” 按 钮 。 

(5) 编写 代码 。 在 “代码 "视图 下 ,将 文字 “此 处 显示 class "login” 的 内 容 " 替 换 为 如 
下 代码 : 


旧 密 码 :<input type="password" name="oldpwd" /><br> 

新 密码 :<input type="password" name="newpwdl" /><br> 

新 密码 :<input type="password" name="newpwd2" /><br> 

<p><input name="xg" type="submit" value=" 修 改 "/></p> 

(6) 更 新 首页 。 在 “文件 ”面板 中 双击 index. php, 在 “设计 ”视图 下 ,选中 文字 “修改 密 
码 ”, 在 “属性 ”面板 的 “链接 ” 框 中 输入 xgmm. php ,保存 并 关闭 此 文件 。 


2. 设计 修改 密码 的 网 页 程序 


(1) 新 建 网 页 。 单 击 “ 文 件 " 菜 单一 “新 建 "选项 ,选择 “空白 页 ”,“ 页 面 类 型 "为 PHP， 
“布局 ”为 无 , 单 击 “ 创 建 " 按 钮 。 
(2) 编写 代码 。 在 “代码 "视图 下 ,在 原 有 代码 的 最 后 添加 以 下 代码 : 


<?php 
if (!isset($ SESSION)) 
session start(); // 启动 SESSION 
header ("Content-type: text/html; charset=utf-8"); // 设置 网 页 编码 为 utf-8 
include "connections/wssd.php"; // 包含 连接 配置 文件 


《8 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版) 


if (isset($ SESSION['islogin']) && $ SESSION['islogin'] ==1) 
{ // 如 果 未 填写 密码 , 则 跳 转 回 密码 修改 页 面 
if (empty($_ POST["oldpwd"]) ||lempty($ POST["newpwd1"])||lempty($ POST["newpwd2"])) 
{ header("refresh:10;url=http://localhost/wssd/xgmm.php"); 
echo "密码 不 能 为 空 ,10 秒 后 自动 跳 转 到 修改 密码 页 !"; } 
else 
{ S$oldpwd =$ POST["oldpwd"]; 
$newpwdl =$_POST["newpwd1"]; 
$newpwd2 =$_POST["newpwd2"]; 
$userid =$_SESSION["userid"]; 
if ($newpwd1l !==$newpwd2) ”// 若 两 次 输入 的 新 密码 不 一 致 , 则 跳 转 回 密码 修改 页 面 
{ header ("refresh:10;url=http://localhost/wssd/xgmm.php"); 
echo "两 次 输入 的 密码 不 一 致 ,10 秒 后 自动 跳 转 到 修改 密码 页 !";  } 


else 
{ S$oldpwd =md5 (Soldpwd) 
$sql ="select * from hyb where 会 员 账 号 ='$userid' and 密码 = '$oldpwd'"; 
$result =mysql query($sql); 
$num =mysql num rows ($result); 
if (empty ($num)) // 车 搜索 为 空 , 则 旧 密 码 错 误 , 跳 转 回 密码 修改 页 面 
{ header("refresh:10;url=http://localhost/wssd/xgmm.php"); 
echo " 旧 密 码 错 误 ,10 秒 后 自动 跳 转 到 修改 密码 页 !"; } 


else 
{ S$newpwdl =md5 ($newpwd1); 
$sqlnew ="update hyb set 密码 ='$newpwdl' where 会 员 账 号 ='$ userid' "; 
$resultnew=mysql query ($sqlnew); 
if( $resultnew ) // $resultnew 为 真 ,密码 修改 成 功 
{ header ("refresh:5;url=http://localhost/wssd "); 
echo "密码 修改 成 功 ,5 秒 后 自动 跳 转 到 主页 !"; } 


else // $resultnew 为 假 ,密码 修改 失败 
{ header("refresh:10;url=http://localhost/wssd"); 
echo" 密 码 修改 失败 ,10 秒 后 自动 跳 转 到 主页 !"; } 
下 


else 
{ header ("refresh:10;url=http://localhost/wssd"); 


echo " 非 正常 访问 ,10 秒 后 自动 跳 转 到 主页 !"; } 


?> 


(3) 保存 文件 。 单 击 “ 文 件 ” 菜 单一 “另存 为 ”选项 ,输入 文件 名 xgmm. act. php, 保 存 
并 关闭 文件 。 


(4) 普通 用 户 修改 密码 。 浏 览 index. php, 输 入 普通 用 户 名 及 密码 后 ,在 图 7-5 中 单 
击 “ 修 改 密码 "链接 ,浏览 器 操作 区 域 显示 的 信息 如 图 7-30 所 示 , 可 以 修改 用 户 密码 。 


六 、 思 考题 


设计 修改 密码 的 网 页 程序 时 ,如 何 能 更 详细 地 验证 输入 信息 的 有 效 性 ? 


第 7 单元 ”动态 网 页 程序 设计 (9 


第 8 单元 


Pe 


电子 邮箱 平台 的 建设 与 管理 


电子 邮件 又 称 为 Email(Electronic Mail) ,是 网 络 用 户 之 间 通 过 计算 机 和 通信 网 络 实 
现 信息 交换 的 主要 方式 。 电 子 邮 件 廉价 .快速 和 形式 多 样 , 因 此 它 也 是 互联 网 中 最 重要 的 
服务 之 一 。 电 子 邮 箱 是 具有 存储 和 收发 电子 邮件 功能 的 信息 平台 ,许多 网 站 为 了 提高 用 
户 忠诚 度 和 访问 频率 ,都 为 用 户 提供 电子 邮箱 。 

本 单元 建设 一 个 名 为 TestMail 的 电子 邮箱 平台 ,通过 连接 本 地 Mercury 邮件 服务 
器 ,为 用 户 提供 登录 ,收发 邮件 和 查看 邮件 等 功能 。 通 过 电子 邮箱 平台 的 设计 过 程 , 了 解 
电子 邮件 相关 协议 和 技术 ,掌握 电子 邮箱 平台 设计 和 建设 的 过 程 及 方法 。 


8.1 使 用 电子 邮箱 的 一 般 过 程 


一 、 实 验 目的 


通过 在 已 有 的 邮箱 平台 中 注册 、 登 录 和 收发 邮件 ,了 解 电子 邮箱 平台 的 组 成 和 常用 
功能 。 


二 、 实 验 任务 


(1) 在 新 浪 邮 箱 平台 中 申请 并 登录 电子 邮箱 。 
(2) 使 用 新 浪 邮箱 发 送 并 接收 电子 邮件 。 


三 、 任务 分 析 


新 浪 电子 邮箱 是 常见 的 免费 电子 邮箱 平台 ,通过 在 新 浪 电子 邮箱 注册 用 户 ,可 以 获得 
邮箱 地 址 。 向 所 申请 的 邮箱 地 址 发 送 一 封 测试 邮件 ,使 用 收 件 箱 查看 收 到 的 邮件 内 容 , 熟 
悉 电 子 邮 件 收发 的 常用 过 程 。 


四 、 预 备 知识 


(1) 电子 邮箱 类 型 。 根 据 电子 邮箱 使 用 者 和 邮箱 后 缀 的 不 同 ,电子 邮箱 可 分 为 个 人 
邮箱 和 企业 邮箱 两 类 。 个 人 邮箱 大 多 提供 免费 服务 ,缺乏 管理 功能 ,电子 邮箱 地 址 用 运营 
商 地 址 结尾 。 企 业 邮 箱 是 为 企业 用 户 开发 的 邮箱 服务 ,拥有 更 多 的 服务 和 管理 功能 ,以 收 
费 为 主 ,电子 邮箱 地 址 用 企业 域名 结尾 。 

(2) 电子 邮箱 地 址 ,也 称 邮箱 账号 。 格 式 为 “用 户 名 @ 邮 箱 服务 器 地 址 ”, 如 website_ 
2016@sina. com。 其 中 用 户 名 是 邮箱 服务 器 中 所 使 用 的 登录 名 ,@ 为 用 户 名 与 邮箱 服务 
器 地 址 的 分 隔 符 。 


五 、 技 能 点 


(1) 注册 邮箱 用 户 。 在 电子 邮箱 网 站 中 ,按照 网 站 规则 正确 填写 注册 信息 ,完成 电子 
邮箱 地 址 的 申请 。 
(2) 收发 电子 邮件 。 写 电子 邮件 并 添加 附件 ,向 本 用 户 地 址 发 送 邮件 并 查收 。 


六 、 注 意 事 项 


(1) 在 电子 邮箱 网 站 注册 用 户 时 ,不 同 网 站 对 用 户 名 和 密码 要 求 不 同 ,如 新 浪 电子 邮 
箱 网 站 中 用 户 名 命名 规则 为 : 4 一 16 个 字符 ,可 使 用 英文 .数字 和 下 面 线 ,下 面 线 不 能 在 
首尾 且 不 能 全 为 数字 。 用 户 密码 的 规则 为 : 6 一 16 个 字符 ,英文 字母 区 分 大 小 写 。 填 写 
注册 信息 时 需要 按照 网 站 规则 正确 填写 。 

(2) 电子 邮箱 网 站 的 每 个 用 户 名 都 必须 唯一 。 要 注册 的 用 户 名 车 已 被 注册 , 则 可 以 
通过 添加 数字 或 下 画 线 更 改 用 户 名 。 在 某 些 提供 手机 号 注册 的 网 站 中 ,也 可 以 使 用 手机 
号 作为 用 户 名 。 


七 、 实验 步 又 


1. 申请 并 登录 电子 邮箱 账号 


(1) 登录 电子 邮箱 注册 页 面 。 打 开 浏 览 器 ,输入 http://mail. sina. com, 进 入 新 浪 电 
子 邮箱 平台 ,在 “免费 邮箱 账号 登录 ”选项 卡 中 单 击 “ 注 册 ” 按 钮 ,打开 电子 邮箱 注册 页 面 。 

(2) 填写 用 户 注册 信息 。 在 电子 邮箱 注册 页 面 中 ,填写 可 用 的 用 户 名 并 选择 邮件 服 
务 器 地 址 ,填写 用 户 密码 和 验证 码 , 最 后 单 击 “ 立 即 注 册 ” 按 钮 。 注 册 成 功 后 ,所 填写 的 账 
户 地 址 就 是 用 户 的 邮箱 地 址 。 

(3) 登录 邮箱 。 重 新 打开 新 浪 电子 邮箱 平台 ,在 “邮箱 账号 登录 ”选项 卡 中 ,填写 所 申 
请 的 邮箱 地 址 和 密码 , 单 击 “ 登 录 ” 按 钮 ,进入 用 户 邮 箱 。 
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2. 收发 电子 邮件 


(1) 发 送 测试 邮件 。 登 录用 户 邮箱 后 , 单 击 页 面 左 侧 的 “ 写 信 ”按钮 ,打开 邮件 编辑 页 
面 。 在 “发 件 人 ”文本 框 中 填写 用 户 邮箱 地 址 ,在 “ 收 件 人 ”文本 框 中 填写 相同 的 邮箱 地 址 ， 


在 “主题 "文本 框 中 填写 邮件 标题 ,在 下 方 填写 邮件 正文 内 容 , 如 图 8-1 所 示 。 单 击 “ 发 送 ” 
按钮 ,完成 邮件 发 送 。 








| Dm ens || eumm || me | 
区 发 件 人 : website_2016@sinacom ~ 
星 标 邮件 
收 件 人 : website_ 2016 <website 2016@sina.com> x 
草稿 夹 1 
已 发 送 主题 。” 测试 邮件 
订阅 邮件 入 添加 附件 (50M) | 由 网 盘 附 件 (2G) 
ee TB7UA 由 到 加 
更 多 分 类 您 好 ， 
部 箱 
这 是 一 封 测试 邮件 ， 请 勿 回复 。 





图 8-1 新 浪 邮箱 的 邮件 编辑 页 面 


(2) 接收 电子 邮件 。 单 击 “ 收 件 夹 ” 链 接 , 可 以 查看 已 经 收 到 的 邮件 ; 单 击 “ 收 信 ” 按 
钮 ,可 以 刷新 收 件 夹 。 如 收 到 测试 邮件 , 单 击 邮 件 标 题 ,查看 邮件 基本 信息 和 内 容 。 


八 、 思 考题 


(1) 编写 电子 邮件 后 ,如 果 有 多 个 接收 者 ,应 该 如 何 操作 ? 如 何 才能 让 接收 者 在 收 到 
邮件 后 看 不 到 其 他 接收 者 ? 


(2) 电子 邮箱 网 站 由 哪些 部 分 组 成 ,你 使 用 过 的 电子 邮箱 有 哪些 不 足 ? 


8.2 建立 电子 邮箱 站 点 
一 、 实 验 目 的 


在 XAMPP 环境 下 ,用 Dreamweaver 创建 和 配置 电子 邮箱 站 点 ,掌握 建立 电子 邮箱 
站 点 的 基本 过 程 和 方法 。 


二 、 实 验 任 务 


(1) 启动 服务 器 并 修改 邮件 服务 配置 。 
(2) 在 Dreamweaver 中 创建 TestMail 站 点 并 设置 测试 服务 器 。 
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(3) 在 站 点 中 添加 PHP 测试 页 面 ,测试 站 点 配置 是 否 正确 。 
三 、 任 务 分 析 


为 了 提供 电子 邮件 的 收发 功能 ,除了 Web 服务 器 和 数据 库 服 务 器 ,电子 邮箱 站 点 还 
需要 有 邮件 服务 器 的 支持 。 邮 件 服务 器 用 于 提供 邮件 服务 ,可 以 通过 连接 第 三 方 邮箱 网 
站 获取 ,也 可 以 在 本 地 直接 安装 。XAMPP 软件 包 内 集成 了 Mercury 邮件 传输 系统 ,通过 
开启 Mercury 并 修改 相关 配置 ,可 以 获得 电子 邮件 服务 。 

使 用 Dreamweaver 设计 TestMail 电子 邮箱 平台 。 首 先 需 要 创建 站 点 ,配置 数据 库 
服务 器 和 页 面 服务 器 ,通过 创建 测试 页 面 查看 站 点 是 否 配置 正确 。 


四 、 预 备 知识 


(1) 电子 邮件 服务 器 。 提 供电 子 邮件 收发 功能 的 软件 ,是 电子 邮箱 系统 的 核心 。 它 
为 每 个 用 户 账号 都 分 配 一 个 位 于 邮件 服务 器 中 的 文件 夹 , 用 于 接收 邮件 ,也 帮助 用 户 将 邮 
件 发 送 到 收 件 人 的 电子 邮件 服务 器 。 为 了 统一 邮件 收发 规则 ,邮件 服务 器 都 采用 标准 协 
议 , 如 用 SMTP 协议 发 送 电子 邮件 ,用 POP3 协议 或 IMAP 协议 接收 电子 邮件 。 邮 件 收 
发 过 程 如 图 8-2 所 示 。 


国 =: SMTP 协 议 ss: 
IMAP 协 议 


发 件 人 用 户 端 发 件 人 邮件 服务 器 。 收 件 人 邮件 服务 器 收 件 人 用 户 端 
图 8-2 邮件 收发 过 程 和 常用 协议 


(2) POP3(Post Office Protocol) 。 电 子 邮局 协议 ,功能 是 让 收 件 人 从 电子 邮箱 中 将 
电子 邮件 读 到 本 地 计算 机 上 ,主要 用 于 本 地 计算 机 安装 的 邮件 客户 端 ( 如 Outlook 
Express) ,在 客户 端的 操作 不 会 直接 反馈 到 服务 器 上 。 

(3) IMAP(Internet Mail Access Protocol) 。 互 联网 消息 访问 协议 ,与 POP3 协议 类 
似 ,也 可 以 用 来 接收 邮件 、 删 除 邮件 或 询问 是 否 有 新 邮件 。 不 同 的 是 ,IMAP 提供 电子 邮 
件 服务 器 与 用 户 端 之 间 的 双向 通信 ,用 户 端的 操作 都 会 反馈 到 服务 器 上 。 

(4) SMTP(Simple Mail Transfer Protocol)。 简 单 邮件 传输 协议 , 它 是 一 组 由 源 地 
址 到 目的 地 址 传送 邮件 的 规则 ,用 于 控制 邮件 的 中 转 方式 ,找到 目的 地 。 主 要 用 于 电子 邮 
件 的 发 送 过 程 。 


五 、 技 能 点 





(1) 启动 邮件 服务 。 正 确 启 动 并 配置 Mercury 邮件 服务 器 。 


第 8 单元 电子 邮箱 平台 的 建设 与 管理 


(2) 设置 测试 服务 器 。 根 据 当 前 服务 器 软件 环境 ,正确 地 配置 测试 服务 器 。 
(3) 创建 测试 页 面 。 用 Dreamweaver 在 站 点 中 创建 并 编写 测试 页 面 ,通过 测试 服务 
器 显示 页 面 结果 。 


六 、 注 意 事项 


(1) 使 用 Mercury 发 送 邮 件 时 ,默认 只 能 发 送 本 地 的 测试 邮件 ,只 有 修改 默认 配置 
后 ,才能 收发 网 络 邮 件 。 

(2) 安装 XAMPP 时 ,如 果 安 装 路 径 中 出 现 空格 ,如 c:\program files\xampp ,发 送 邮 
件 时 会 出 现 问 题 。 此 时 需要 将 安装 目录 中 sendmail 文件 夹 复制 到 根 目录 中 ,并 修改 配置 
文件 中 sendmail_path 的 值 。 

(3) 使 用 Dreamweaver 定义 站 点 时 ,站 点 文件 夹 名 称 中 不 应 该 出 现 空格 或 任何 特殊 
字符 ,否则 可 能 造成 服务 器 访问 失败 。 


七 、 实 验 步骤 


1. 启动 并 配置 服务 器 


(1) 启动 服务 器 。 打 开 XAMPP 控制 面板 ,分 别 单 击 Apache .MySQL 和 Mercury 按 
钮 组 中 的 Start 按钮 启动 相应 服务 , 若 正常 启动 , 则 Start 按钮 转变 成 Stop 按钮 , 且 在 消 
息 提示 框 中 显示 服务 状态 为 running。 

(2) 配置 Mercury 邮件 服务 器 。 在 XAMPP 控制 面板 中 , 单 击 Mercury 动作 按钮 组 
中 的 Admin 按钮 ,打开 Mercury 界面 。 单 击 Configuration 菜单 Mercury SMTP Server 
一 Connection control 选项 卡 ,去 掉 Do not permit SMTP relaying of non-local mail 项 的 
勾 选 , 单 击 “ 确 定 ” 按 钮 ,如 图 8-3 所 示 。 


























[Ladd restrcton | [Change selection | [Remove selecton| 








Relaying control 
加 Do not permit SMTP relaying of norlocal mall 
加 Use stict local relaying restiictions [see help} 
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(3) 修改 PHP 配置 文件 。 在 XAMPP 控制 面板 中 , 单 击 Apache 按钮 组 中 的 config 一 
php. ini 选项 ,打开 PHP 配置 文件 。 搜 索 关 键 字 mail function 找到 邮件 函数 配置 项 ,去 掉 
如 下 配置 行 前 的 分 号 ”; "注释 。 

7 SMTP=localhost 

; smtp port=25 

;sendmail path="\"\xampp\sendmail\sendmail.exe\" -t" 


2. 使 用 Dreamweaver 定义 站 点 


(1) 指定 工作 文件 来。 在 XAMPP 安装 目录 下 的 htdocs 文件 夹 中 ,新 建 名 为 
TestMail 的 文件 夹 。 打 开 Dreamweaver 软件 , 单 击 “ 站 点 "菜单 “新 建站 点 "选项 。 输 入 
“站 点 名 称 ” 为 Test Mail,“ 本 地 站 点 文件 夹 ”为 D:\TestMail。 

(2) 指定 测试 服务 器 。 在 站 点 设置 对 话 框 中 单 击 服 务 器 ”一 “十 ”按钮 ,添加 新 服务 
器 。 在 “基本 ”选项 卡 中 ,将 服务 器 命名 为 XAMPP Server, 选 择 “ 连 接 方法 ”为 “本 地 /网 
络 ”, 设 置 “ 服 务 器 文件 夹 ” 为 htdocs 目录 下 的 TestMail 文件 夹 ,在 Web URL 输入 
http://localhost/testmail, 如 图 8-4 所 示 。 





图 8-4 服务 器 设置 对 话 框 


(3) 指定 服务 器 模式 。 选 择 “ 高 级 ”选项 卡 , 修 改 * 服 务 器 模型 "为 PHP MySQL, 单 击 
“保存 ”按钮 返回 站 点 设置 页 面 。 选 中 “测试 " 复 选 框 , 单 击 “ 保 存 ” 按 钮 完成 站 点 设置 。 


3. 测试 PHP 站 点 


(1) 新 建 PHP 网 页 。 在 Dreamweaver 中 , 单 击 “ 文 件 ” 菜 单一 “新 建 ”* 一 “空白 页 ”一 
PHP 选项 , 单 击 “ 创 建 " 按 钮 ,添加 一 个 PHP 页 面 。 打开“ 代码 ”视图 ,在 二 body 二 和 
二 /body 二 之 间 输 入 以 下 代码 ,用 于 查看 PHP 服务 器 信息 。 


<?php phpinfo(); ?> 


(2) 查看 PHP 配置 项 。 单 击 “ 实 时 视图 ”按钮 ,将 该 页 面 命名 为 test. php, 存 储 到 
TestMail 文件 夹 ,此 时 PHP 图 标 显示 为 服务 器 的 PHP 信息 ,查看 sendmail 配置 项 是 否 
正确 。 


八 、 思 考题 


(1) 如 果 不 使 用 Mercury 做 邮件 服务 器 ,还 有 哪些 方法 实现 邮件 服务 器 功能 ?应 该 
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如 何 修改 配置 文件 ? 

(2) 使 用 Dreamweaver 创建 站 点 有 什么 作用 ? 在 什么 情况 下 Dreamweaver 测试 网 
页 前 必须 先 创建 站 点 ? 

(3) 在 Dreamweaver 创建 站 点 时 ,可 以 为 服务 器 选择 远程 和 测试 两 种 属性 ,这 两 种 属 
性 的 区 别 是 什么 ? 适用 于 什么 情况 ? 


8.3 设计 电子 邮箱 数据 库 


一 、 实 验 目 的 
通过 电子 邮箱 平台 数据 库 的 设计 过 程 , 掌 握 数据 库 设 计 步 骤 和 方法 。 
二 、 实 验 任务 


(1) 确定 电子 邮箱 功能 。 

(2) 设计 电子 邮箱 数据 表 的 概念 结构 和 逻辑 结构 。 

(3) 使 用 PHPMyAdmin 创建 TestMail 数据 库 并 添加 邮件 表 和 会 员 表 。 
(4) 在 Mercury 邮件 服务 器 中 添加 用 户 。 


三 、 任务 分 析 


设计 电子 邮箱 数据 库 , 首 先 要 设 定 系 统 功能 ,通过 ER 图 描述 TestMail 的 数据 库 概 
念 结构 。 用 户 数据 使 用 会 员 表 存储 ,为 了 实现 电子 邮件 的 收发 ,需要 为 会 员 表 中 的 记录 手 
动 添加 相应 的 Mercury 账户 。 邮 件数 据 存储 在 邮件 表 中 ,使 用 PHPMyAdmin 建立 邮件 


四 、 预 备 知识 


一 封 完整 的 电子 邮件 由 邮件 头 和 邮件 体 两 部 分 组 成 。 邮 件 头 用 于 描述 邮件 的 基本 信 
息 ,一 般 包 含 以 下 部 分 ， 

(1) 邮件 标题 。 电 子 邮 件 主题 ,是 电子 邮件 的 必要 组 成 部 分 。 

(2) 邮寄 时 间 。 电 子 邮 件 发 送 时 间 , 通 常 由 邮件 服务 器 自动 填写 。 

(3) 发 件 人 。 电 子 邮 件 发 送 人 ,格式 为 邮箱 地 址 。 

(4) 收 件 人 。 电 子 邮 件 接收 人 ,可 以 是 一 个 或 多 个 邮箱 地 址 。 

邮件 体 用 于 描述 邮件 的 具体 内 容 , 一 般 包含 以 下 部 分 : 

(1) 邮件 正文 。 电 子 邮 件 的 主要 内 容 , 通 常 为 文字 和 图 片 。 

(2) 邮件 附件 。 附 在 电子 邮件 内 的 一 个 或 多 个 电子 文件 , 随 邮件 一 起 发 送 。 邮 件 附 
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@ 


件 可 以 从 信件 上 分 离 出 来 ,作为 独立 的 文件 使 用 。 


五 、 技 能 点 


(1) 设计 系统 功能 。 根 据 实际 情况 设 定 电子 邮箱 平台 功能 。 

(2) 设计 数据 库 ER 图 。 根 据 系统 功能 ,设计 实体 结构 和 实体 间 关系 ,并 绘制 ER 图 。 

(3) 创建 数据 表 。 能 使 用 ER 图 设计 数据 表 结 构 并 通过 PHPMyAdmin 添加 数 
据 表 。 


六 、 注 意 事 项 


(1) 设计 数据 表 时 ,车 两 个 实体 之 间 存 在 关系 , 则 需要 建立 表 间 关联 。 根 据 系统 功能 
确定 主 从 关系 ,在 从 表 中 添加 相应 字段 作为 外 键 ,实现 关联 和 参照 完整 性 。 

(2) Mercury 邮件 服务 器 将 用 户 配置 文件 和 用 户 邮箱 放置 在 Mercury 安装 目录 下 的 
Mail 文件 夹 内 。 其 中 PMAIL. USR 文件 用 于 存储 用 户 信息 ,可 以 通过 记事 本 等 程序 修改 
该 文件 ,实现 用 户 的 批量 添加 。 


七 、 设 计 步 又 


1. 系统 功能 分 析 


TestMail 是 一 个 简单 的 电子 邮箱 平台 ,平台 用 户 信息 需要 手动 添加 到 数据 表 中 , 系 
统 提 供 如 下 服务 功能 : 

(1) 网 上 书店 会 员 可 以 输入 会 员 账 号 和 密码 登录 TestMail。 

(2) 系统 为 用 户 提供 发 送 邮件 的 功能 ,发 送 成 功 的 邮件 标记 为 已 发 送 ,存储 在 电子 邮 
箱 数据 库 。 在 TestMail 中 ,电子 邮件 被 设 定 为 只 有 一 个 收 件 人 , 且 不 包含 附件 的 简单 
邮件 。 

(3) 系统 为 用 户 提 供 收取 、 查 看 和 删除 电子 邮件 的 功能 。 用 户 可 以 查看 已 收 到 或 已 
发 送 的 电子 邮件 ,通过 单 击 邮件 标题 可 以 查看 内 容 。 


2. 概念 结构 设计 


根据 TestMail 电子 邮箱 的 功能 设 定 , 将 系统 所 需 数据 分 为 用 户 信息 和 邮件 信息 两 个 
实体 类 型 ,描述 数据 库 概 念 模型 的 ER 图 ,如 图 8-5 所 示 。 

用 户 信 息 实体 负责 用 户 登录 和 信息 管理 ,包括 的 属性 有 账号 ,密码 、 姓 名 和 安全 邮箱 。 
用 户 账号 为 主键 ,账号 和 密码 用 于 用 户 登录 ,姓名 用 于 显示 欢迎 页 面 ,邮箱 用 于 系统 发 送 
安全 邮件 ,如 发 送 重 置 密 码 邮件 。 

邮件 信息 实体 负责 登录 用 户 的 邮件 收发 和 邮件 管理 ,包括 的 属性 有 编号 、 标 题 、 内 容 、 
时 间 、 收 件 人 ,发 件 人 和 邮件 标记 。 邮 件 编号 为 主键 ,新 邮件 自动 编号 ,邮件 标记 为 当前 邮 
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图 8-5 电子 邮箱 数据 库 ER 图 


件 的 管理 标记 ,包括 收 件 ,发 件 和 删除 三 种 。 

用 户 信息 实体 和 邮件 信息 实体 之 间 为 1 对 的 拥有 关系 。 在 邮件 表 中 添加 “用 户 账 
号 "作为 外 键 ,建立 表 间 关联 。 

3. 逻辑 结构 设计 

通过 ER 图 定义 电子 邮箱 平台 的 数据 表 结 构 。 数 据 库 中 包含 会 员 表 HYB, 如 表 8-1 
所 示 ,存储 平台 用 户 的 数据 ;邮件 表 YJB, 如 表 8-2 所 示 ,存储 邮件 信息 数据 。 两 个 表 通 过 









































“用 户 账 号 ?字段 建立 关联 。 
表 8-1 HYB 表 的 结构 
字段 名 称 数据 类 型 长 度 / 值 设计 说 明 
用 户 账 号 Char 10 非 空 值 ,HYB 表 的 主键 和 主 属性 
密码 Varchar 32 非 空 值 
姓名 Varchar 10 非 空 值 
邮箱 Varchar 30 
表 8-2 YJB 表 的 结构 
字段 名 称 数据 类 型 长 度 / 值 设计 说 明 
邮件 编号 Int 10 自 增 型 值 ,YJB 表 的 主键 和 主 属性 
用 户 账 号 Char 10 非 空 值 ,YJB 表 的 外 键 
标题 Varchar 50 非 空 值 
内 容 Longtext 
时 间 Datetime 
发 件 人 Varchar 30 
收 件 人 Varchar 30 
邮件 标记 Set ,2',3" 非 空 值 。1 一 收 件 ; 2 一 发 件 ; 3 一 删除 











4. 创建 数据 库 和 数据 表 
在 PHPMyAdmin 主页 中 单 击 “ 数 据 库 ” 选 项 卡 ,在 “新 建 数 据 库 ” 文 本 框 中 输入 
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testmail, 在 “整理 ”列表 中 选择 gb2312_chinese_ci, 单 击 “ 创 建 ”按钮 完成 电子 邮箱 数据 库 
的 创建 。 

在 导航 面板 中 单 击 testmail 进入 电子 邮箱 数据 库 页 面 。 设置“ 新 建 数据 表 ” 的 “名 字 ” 
为 HYB, “字段 数 ”为 4, 单 击 “执行 "按钮 进入 HYB 表 设 计 页 面 。 按 照 表 8-1 所 示 的 表 结 
构 输 入 各 字段 的 内 容 , 单 击 “ 保 存 ” 按 钮 完成 会 员 表 的 创建 。 用 同样 的 方法 ,按照 表 8-2 所 
示 的 表 结 构建 立 邮 件 表 YJB。 

在 TestMail 数据 库 页 面 中 , 单 击 “ 设 计 器 "选项 卡 ,以 HYB 为 主 表 , YJB 为 从 表 , 通 
过 “用 户 账号 ”为 这 两 个 表 建 立 关 联 。 

5. 添加 Mercury 账户 

在 XAMPP 控制 面板 中 , 单 击 Mercury 动作 按钮 组 中 的 admin 按钮 ,打开 Mercury 
界面 。 单 击 configuration 菜单 -manage local users 一 Add 按钮 ,在 弹出 的 对 话 框 中 设置 


Username 为 会 员 表 中 的 “用 户 账号 ”字段 值 ,Personal name 为 “姓名 ”字段 值 , 单 击 OK 按 
钮 完成 一 个 账户 的 添加 。 用 同样 方式 添加 会 员 表 的 其 他 用 户 信息 。 





八 、 思 考题 


如 果 电 子 邮 箱 网 站 支持 多 人 发 送 ,并 可 以 添加 邮件 附件 ,应 该 如 何 设计 数据 表 ? 数据 
表 中 新 增加 字段 的 数据 类 型 该 如 何 设 计 ? 


8.4 设计 用 户 端 页 面 
一 、 实 验 目的 


通过 电子 邮箱 平台 主页 面 和 登录 页 面 的 设计 和 实现 ,掌握 使 用 Dreamweaver 和 PHP 
代码 实现 动态 页 面 和 多 页 面 显示 的 方法 。 


二 、 实 验 任务 


(1) 使 用 Dreamweaver 创建 电子 邮箱 主页 面 ,用 户 登录 后 才能 访问 。 
(2) 使 用 Dreamweaver 创建 电子 邮箱 的 用 户 登 录 页 面 。 


三 、 任务 分 析 


TestMail 电子 邮箱 平台 包含 5 个 页 面 : 电子 邮箱 主页 面 Index. php、 用 户 登 录 页 面 
Login. php、 邮箱 页 面 Mailbox. php、 邮 件 查 看 页 面 Mail. php 和 邮件 发 送 页 面 
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@ 


Sendmail. php 。 

登录 页 面 是 用 户 与 电子 邮箱 平台 的 接口 , 若 用 户 登 录 成 功 ,建立 Session 会 话 并 跳 转 
到 主页 面 。 主 页 面 可 以 根据 用 户 的 选择 实现 邮箱 页 面 、 邮 件 查看 页 面 和 邮件 发 送 页 面 的 
显示 。 当 用 户 选择 退出 或 未 登录 访问 主页 面 时 ,将 强制 跳 转 到 登录 页 面 。 





四 、 预 备 知识 


(1) Session 会 话 。 也 称 为 “会 话 控 制 ”, 通 过 Session 对 象 存储 用 户 与 服务 器 会 话 所 
需 信息 ,如 用 户 名 或 密码 等 。 在 会 话 存续 期 间 , 网 站 其 他 页 面 被 访问 时 ,可 以 根据 Session 
对 象 的 信息 识别 用 户 。 

(2) 服务 器 行为 。 为 方便 向 页 面 添 加 动态 内 容 ,Dreamweaver 提供 一 组 内 署 的 服务 
器 行为 ,可 以 在 网 页 中 自动 生成 PHP 代码 。 添 加 服务 器 行为 时 ,通常 会 包含 连接 数据 库 
和 建立 Session 会 话 的 PHP 代码 。 


五 、 技 能 点 


(1) 设计 网 页 元 素 。 使 用 Dreamweaver 添加 页 面 元 素 ,实现 页 面 设计 。 

(2) 使 用 服务 器 行为 。 根 据 系统 功能 选择 Dreamweaver 服务 器 行为 ,根据 需求 正确 
设置 相应 参数 。 

(3) 编写 PHP 代码 。 使 用 PHP 代码 ,根据 用 户 操作 显示 不 同 页 面 。 


六 、 注 意 事项 


(1) 使 用 Dreamweaver 向 网 页 添加 数据 库 相 关 的 服务 器 行为 时 ,需要 设置 测试 服务 
器 并 绑 定 记 录 集 。 数 据 库 连接 一 经 创建 ,站 点 目录 中 的 其 他 页 面 都 可 以 直接 使 用 服务 器 
行为 。 

(2) 只 有 登录 成 功 的 会 员 才 能 浏览 电子 邮箱 主页 面 , 所 以 要 在 主页 面 添加 用 户 访问 
限制 ,防止 匿名 用 户 直接 使 用 URL 访问 。 会 员 表 中 的 会 员 可 以 登录 主页 面 ., 如 果 在 
Mercury 软件 中 未 添加 账户 ,无 法 正常 使 用 邮件 收发 功能 。 


七 、 实 验 步 又 


1. 创建 电子 邮箱 主页 面 


(1) 新 建 Index 页 面 。 打 开 Dreamweaver 的 文件 面板 .在 列表 框 中 单 击 TestMail , 展 
开 站 点 根 目 录 。 在 根 目录 右键 菜单 中 , 单 击 “ 新 建文 件 ? 选 项 ,将 文件 命名 为 "Index. php” 
并 双击 打开 。 
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(2) 设计 主页 面 框架 。 在 Index. php 文件 的 设计 视图 中 ,添加 标题 栏 .导航 条 和 脚 
注 , 设 计 结果 如 图 8-6 所 示 。 





图 8-6 邮箱 主页 面 设计 


单 击 导航 条 中 的 “ 收 件 箱 ” 链 接 , 在 “属性 ”面板 中 设 定 链接 目标 为 *Index. php?lmbs 
三 收 件 箱 ”。 用 同样 的 方法 设 定 “ 发 件 箱 ” 和 “发 邮件 "的 链接 目标 为 “Index. php?lmbs 一 
发 件 箱 ” 和 “Index. php?lmbs 一 发 邮件 >。 在 导航 条 代码 下 添加 如 下 PHP 语句 : 


<?php 

if(isset($ GET['lmbs'])){ $lmbs=$ GET['lmbs'];} 

else{$lmbs="";} 

switch ($lmbs){ 
case " 收 件 箱 ": include "Mailbox.php";break; 
case "发 件 箱 ": include "Mailbox.php";break; 
case "发 邮件 ": include "Sendmail .php";break; 
case "查看 邮件 ": include "Mail.php";break; 
default: include "Mailbox.php";} 


-> 

(3) 建立 数据 库 连 接 。 打 开 “ 数 据 库 ” 面 板 , 单 击 " 十 ”>“MySQL 连接 ?选项 。 在 弹出 
的 对 话 框 中 ,设置 连接 名 称 为 Maildb, MySQL 服务 器 为 Localhost, 用 户 名 为 root, 密 码 
为 root 用 户 实际 密码 ,数据库 为 testmail。 单 击 “ 测 试 " 按 钮 查看 是 否 配 置 正确 ,车 成 功 创 
建 , 则 单 击 “ 确 定 ” 按 钮 ,完成 MySQL 数据 库 连 接 。 

(4) 添加 匿名 访问 限制 。 打 开 “ 服 务 器 行为 "面板, 单 击 “ 十 ”>“ 用 户 身 份 验证 ”>“ 限 
制 对 页 的 访问 "选项 。 在 弹出 的 对 话 框 中 单 击 “ 用 户 名 和 密码 " 单 选 按钮 ,设置 "如 果 访 问 
被 拒绝 则 转 到 ;为 Login. php , 单 击 * 确 定 "按钮 完成 设置 。 此 时 如 用 户 未 经 登录 访问 ， 
则 跳 转 到 登录 页 面 。 

(5) 添加 退出 功能 。 打 开 * 服 务 器 行为 ”面板 , 单 击 “ 十 ”用 户 身份 验证 ”一 “注销 用 
户 ” 选 项 。 在 弹出 的 对 话 框 中 设置 “ 单 击 链接 ”为 “退出 ”, 设 置 “在 完成 后 , 转 到 ”为 Login. 
php; 单 击 “ 确 定 ” 按 钮 完成 设置 。 此 时 如 用 户 单 击 “ 退 出 ”链接 , 则 跳 转 到 登录 页 面 。 


2. 创建 用 户 登录 页 面 


(1) 新 建 登 录 页 面 。 在 TestMail 站 点 根 目录 中 , 单 击 右键 菜单 中 的 “新 建文 件 ” 选 
项 ,将 文件 命名 为 Login. php 并 双击 打开 。 
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(2) 设计 登录 页 面 。 在 Index. php 文件 的 设计 视图 中 ,添加 标题 栏 和 用 户 登录 的 表 
单 。 登 录 表 单 Forml 包括 用 于 输入 用 户 名 的 文本 域 User、 输 入 密码 的 文本 域 Password 
和 “登录 ”按钮 ,结果 如 图 8-7 所 示 。 





Ee 
el 






图 8-7 登录 页 面 


(3) 实现 登录 功能 。 打 开 “ 服 务 器 行为 "面板, 单 击 “ 十 ”一 “用 户 身 份 验证 ”>“ 登 录用 
户 ? 选 项 。 在 弹出 的 对 话 框 中 ,设置 连接 验证 为 Maildb, 表格 为 HYB,“ 用 户 名 列 ” 为 “会 
员 账 号 ”,“ 密 码 列 ” 为 “密码 ” ,设置 “如 果 登 录 成 功 , 转 到 ”为 “Index. php?lmbs 一 发 件 箱 ”， 
“如 果 登 录 失败 , 转 到 ”为 Login. php, 如 图 8-8 所 示 , 单 击 “ 确 定 ” 按 钮 完成 设置 。 此 时 如 
用 户 输入 会 员 表 中 的 用 户 名 和 密码 , 则 跳 转 到 主页 面 。 


从 表单 区 取 输 和 :zsal 

用 户 各 字段 Eee 

密码 字 机 Password | 
合用 这 接 汪 [ail ee 

.4 | 


用 户 各 列 : 基于 晤 二 = 二 = 二 = 于 
天 FE 


如 果 登 录 成 功 , 转 到 : Index. php?lmbs= 发 件 箱 BE. 
转 到 前 一 个 URLC 和 0D 果 它 存在 > 

















八 、 思 考题 


(1) 通过 服务 器 行为 添加 用 户 登 录 功 能 时 , Dreamweaver 是 如 何 实 现 定义 用 户 
Session 会 话 的 ? 存储 Session 信息 的 变量 是 什么 ? 如 何 使 用 ? 

(2) 如 果 想 通过 Web 页 面 自动 添加 Mercury 账户 ,应 该 在 TestMail 平台 哪个 文件 
中 修改 ? 当知 道 账户 配置 文件 位 置 时 ,如 何 编写 PHP 代码? 
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8.5 电子 邮件 收发 管理 与 控制 


一 、 实 验 目的 


通过 电子 邮箱 平台 的 邮箱 页 面 、 邮 件 查看 页 面 和 邮件 发 送 页 面 的 设计 与 实现 ,掌握 使 
用 PHP 实现 接收 和 发 送 电 子 邮 件 的 方法 。 


二 、 实 验 任务 


(1) 使 用 Dreamweaver 创建 邮箱 页 面 , 用 于 电子 邮件 的 接收 和 显示 。 
(2) 创建 阅读 邮件 页 面 ,用 于 显示 邮件 具体 内 容 。 
(3) 创建 电子 邮件 发 送 页 面 ,用 于 编写 及 发 送 邮 件 。 


三 、 任务 分 析 


TestMail 电子 邮箱 平台 通过 Mercury 提供 邮件 服务 。 在 Dreamweaver 中 创建 邮箱 
页 面 ,使 用 PHP 的 邮件 接收 函数 登录 Mercury 邮件 服务 器 收取 邮件 ,并 将 邮件 移动 到 邮 
件 表 中 ,通过 绑 定 记录 集 操作 将 邮件 列表 显示 给 用 户 。 

在 邮箱 页 面 中 ,通过 选择 邮件 标题 确定 邮件 编号 ,使 用 邮件 编号 查看 显示 内 容 。 

创建 邮件 发 送 页 面 ,使 用 Spry 验证 文本 框 验证 邮件 格式 是 否 正确 ,再 通过 PHP 邮件 
发 送 函 数 实现 邮件 的 发 送 。 发 送 成 功 的 邮件 存储 到 数据 库 邮件 表 中 。 


四 、 预 备 知识 


邮件 的 发 送 和 接收 需要 通过 PHP 内 置 的 邮件 函数 实现 ,包括 用 于 接收 邮件 的 Imap 
系列 函数 和 发 送 邮件 的 Mail 函数 : 

(1) Imap_open 函数 。 用 于 打开 客户 端 与 邮件 服务 器 之 间 的 IMAP 数据 流 , 语 法 是 
Imap_open( 服 务 器 地 址 ,用 户 名 ,密码 ) ,返回 值 为 IMAP 数据 流 。 

(2) Imap_close 函数 。 用 于 关闭 客户 端 与 邮件 服务 器 之 间 的 IMAP 数据 流 , 语 法 是 
Imap_close(imap 数据 流 ) , 若 成 功 返回 true ,失败 返 回 false。 

(3) Imap_header 函数 。 根 据 邮 件 编号 从 IMAP 数据 流 中 读 取 邮件 头 信息 ,语法 是 
Imap_header(imap 数据 流 , 邮 件 编号 ) ,返回 值 为 邮件 头 对 象 , 其 包括 的 常用 属性 如 表 8-3 
所 示 。 

(4) Imap_body 函数 。 根 据 邮 件 编号 从 IMAP 数据 流 中 读 取 邮 件 正文 ,语法 是 Imap 
_body(imap 数据 流 , 邮 件 编号 ) ,车 成 功 返回 true, 失 败 返回 false。 
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表 8-3 文件 头 对 象 属性 说 明 








属性 名 称 属性 说 明 属性 名 称 属性 说 明 
Toaddress 存储 收 件 人 地 址 Fromaddress 存储 发 件 人 地 址 
Date 存储 发 送 时 间 Subject 存储 邮件 标题 











(5) Imap_num_msg 天 数 。 获 取 当 前 邮箱 内 的 邮件 个 数 , 语 法 是 Imap_num_msg 
(imap 数据 流 ) ,返回 值 为 邮件 数量 。 

(6) Imap_delete 函数 。 根 据 邮 件 编 号 为 邮件 添加 删除 标记 。 添 加 删除 标记 的 邮件 
仍 保留 在 数据 库 内 ,需要 配合 Imap_expunge 函数 实现 真正 的 删除 ,语法 是 Imap_delete 
(imap 数据 流 ,邮件 编 号 ) , 若 成 功 返 回 true, 失 败 返 回 false。 

(7) Imap_expunge 函数 。 删 除 所 有 添加 删除 标记 的 邮件 ,语法 是 Imap_expunge 
(imap 数据 流 ) , 若 成 功 返 回 true, 失 败 返 回 false。 

(8) Mail 函数 。 用 于 从 PHP 脚本 中 直接 发 送 电子 邮件 ,语法 是 Mail( 邮 件 收 件 人 ， 
邮件 标题 ,邮件 正文 ,邮件 头 ), 若 成 功 返 回 true, 失 败 返 回 false, 注 意 ,发 送 成 功 是 指 邮件 
被 成 功 投递 ,并 不 表示 邮件 被 目的 邮件 服务 器 接收 。 


五 、 技 能 点 


(1) 设计 表单 页 面 。 熟 练 使 用 表格 和 表单 ,创建 数据 的 输入 和 显示 页 面 。 

(2) 使 用 PHP 函数。 能 够 熟悉 并 正确 使 用 PHP 邮件 函数 。 

(3) 修改 网 页 代码 。 了 解 Dreamweaver 自动 生成 代码 的 功能 并 能 根据 需要 进行 
修改 。 


六 、 注 意 事项 


(1) IMAP 系列 函数 和 Mail 函数 不 是 PHP 标准 函数 ,使 用 前 需要 服务 器 支持 IMAP 
协议 和 SMTP 协议 。 通 过 Phpinfo 函数 可 以 查看 服务 器 是 否 支 持 ,如 果 不 支 持 ,需要 下 
载 相 应 的 客户 端 程序 。 

(2) 要 在 Dreamweaver 中 添加 重复 区 域 ,需要 绑 定 记 录 集 并 添加 记录 集 到 指定 页 面 
元 素 中 。 选 中 含有 记录 集 的 页 面 元 素 ,通过 “服务 器 行为 "面板 添加 重复 区 域 后 ,如 果 仍 然 
没有 重复 显示 ,需要 确定 记录 集中 是 否 包含 多 条 记录 。 


七 、 实 验 步骤 


1. 创建 邮箱 页 面 


(1) 新 建 邮箱 页 面 。 打 开 Dreamweaver 的 文件 面板 ,在 列表 框 中 单 击 TestMail, 展 
开 站 点 根 目录 。 在 根 目 录 和 右键 菜 单 中 , 单 击 “ 新 建文 件 ” 选 项 ,将 文件 命名 为 *Mailbox. 





(人 为 。 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


php” 并 双击 打开 。 
(2) 转 存 邮件 到 MYSQL。 在 Mailbox. php 文件 的 顶部 添加 如 下 PHP 代码 ,用 于 登 
录 Mercury 邮件 服务 器 , 剪 切 邮件 到 邮件 表 中 。 


<?php 

require once('../Connections/maildb.php'); 

$message=array (); 

$imap=imap open("localhost",$ SESSION['MM Username'],""); 

$totalrows=imap num msg ($mbox); 

if($imap) { for ($i=1;$i<S$totalrows; $i++)1{ 
S$header=imap header ($imap, $i); 
SinsertSOL= "INSERT INTO YJB (用 户 账号 , 标题 , 内 容 , 时 间 ,， 发 
件 人 , 收 件 人 ,邮件 标记 ) VALUES ($_SESSION['MM Username']， 
S$header->subject，imap_body ($imap, $i), $header->date, $header-> 
fromaddress, $header->toaddres, 1)"; 
mysql_select dbl($database maildb, $maildb); 
mysql_ query ($insertSsQL, $maildb) or die(mysql error()); 
imap_delete ($imap, $i); 

} 

}imap_expunge ($imap); 


imap_close ($imap); ?> 


(3) 设计 邮箱 页 面 。 在 Mailbox. php 的 设计 视图 中 ,添加 如 图 8-9 所 示 的 页 面 内 容 
和 表单 元 素 。 使 用 二 ?php echo $_GET[L'Imbs'];? 二 代码 显示 当前 邮箱 类 型 。 





ox Trae or 
图 8-9 邮箱 页 面 设计 视图 





(4) 绑 定 记录 和 集 。 打 开 绑 定 面板 , 单 击 “ 十 ”一 “记录 集 ” 选 项 。 在 弹出 的 对 话 框 中 , 设 
置 名 称 为 MailBoxR ,连接 为 Maildb, 表 格 为 YJB, 设 置 “筛选 列表 ”为 “用 户 账号 ”的 值 等 
同 于 “阶段 变量 " 值 MM_Username, 设 置 “ 排 序列 表 ” 为 时 间 的 降序 排列 。 通 过 “测试 ” 按 
钮 验证 , 单 击 “ 确 定 ” 按 钮 完成 设置 。 

要 在 邮箱 页 面 显示 收 件 箱 和 发 件 箱 内 容 , 需 要 在 生成 代码 中 找到 如 下 语句 ， 


$query_MailBoxR= sprintf ("SELECT * FROM yjb WHERE 用 户 账号 =ss ORDER BY 时 间 
DESC"，GetSOLValueString(S$Scolname MailBoxR, "text")); 


将 其 修改 为 下 列 代码 : 


if($_GET['lmbs']==" 发 件 箱 ") 
$sqlstr="SELECT x FROM yjb WHERE 用 户 账号 =ss AND 邮件 标记 =2 ORDER BY 时 间 


第 8 单元 ”电子 邮箱 平台 的 建设 与 管理 


DESC"; 
else 
$ sqlstr="SELECT * FROM yjb WHERE 用 户 账号 =ss AND 邮件 标记 =1 ORDER BY 时 间 

DESC™; 

$ query MailBoxR = sprintf ($sqlstr, GetSQLValueString ($colname MailBoxR, 

wext")ys 

在 “ 绑 定 ”面板 中 展开 MailBoxR 记录 和 集 , 拖 动 字段 名 到 邮箱 页 面 对 应 位 置 上 ,其 中 
“邮件 编号 "字段 名 放置 到 “选择 ” 复 选 框 上 。 将 邮件 标题 设置 为 如 下 超 链接 ; 

<a href="index.php?lmbs= 查 看 邮件 smailid=<?php echo $row MailBoxR 

[' 邮 件 编号 '] ;?>" > …… 邮件 标题 代码 …… </a> 

(5) 设置 重复 区 域 。 在 设计 视图 中 选中 要 重复 显示 的 记录 集 , 单 击 “ 服 务 器 行为 ” 面 
板 的 “十 ”>“ 重 复 区 域 ”选项 。 在 弹出 对 话 框 中 设置 记录 集 为 MailBoxR, 显 示 为 10 条 记 

将 光标 定位 到 页 面 中 邮件 个 数 统计 , 单 击 “ 服 务 器 行为 "面板 的 “十 ”>“ 显 示 记 录 技 
术 ” 一 “显示 总 记录 数 ” 选 项 ,添加 邮件 计数 器 。 


2. 创建 邮件 查看 页 面 


(1) 设计 邮件 页 面 。 在 站 点 根 目录 , 单 击 右 键 菜单 中 的 “新 建文 件 ” 选 项 ,将 建立 的 文 
件 命名 为 Mail. php 并 双击 打开 。 在 设计 视图 中 ,添加 用 于 显示 文件 内 容 的 表单 ,运行 页 
面 如 图 8-10 所 示 。 





时 间 ，| 2016-03-01 10:00:00 
发 件 人 ， alex_chenejlu. edu. cn 
收 件 人 ， alex_chen@localhost 

主 题 ， 测试 邮件 

您 好 ， 

这 是 一 封 测试 邮件 ， 邮 件 服务 器 工作 正常 。 
祝 万 事 如 意 








图 8-10 邮件 查看 页 面 


(2) 绑 定 记录 集 。 在 “ 绑 定 ”面板 中 , 单 击 “ 十 ”>“ 记 录 集 ”选项 。 在 弹出 的 对 话 框 中 ， 
设置 名 称 为 MailR ,连接 为 Maildb, 表 格 为 YJB, 将 筛选 列表 内 容 设置 为 “邮件 编号 账号 ” 
的 值 等 同 于 “URL 参数 ” 值 mailid。 单 击 “ 测 试 " 按 钮 验证 , 单 击 “ 确 定 ” 按 钮 完成 设置 。 

在 " 绑 定 ”面板 中 展开 MailR 记录 集 ,分 别 拖 动 字段 名 到 邮件 页 面 对 应 行 的 值 域 上 ， 
将 内 容 字段 放置 到 页 面 下 方 区 域 。 
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3. 创建 发 送 邮 件 页 面 


(1) 设计 发 送 邮件 页 面 。 在 TestMail 站 点 根 目录 , 单 击 右键 菜单 中 的 “新 建文 件 " 选 项 ， 
将 文件 命名 为 Sendmail. php 并 双击 打开 。 在 设计 视图 中 分 别 为 发 件 人 sender、 收 件 人 
receiver ,主题 subject 和 内 容 content 添加 “Spry 验证 文本 域 ”。 运 行 页 面 如 图 8-11 所 示 。 





件 人 : [请 输入 电子 邮件 ， 必 十 》 
件 人 : | 《请 输入 电子 邮件 ， 必 十) 
题 : | ( 必 填 ) 

















容 ; 





[El 
图 8-11 发 送 邮 件 页 面 


(2) 邮件 的 发 送 和 存储 。 选 择 发 送 邮件 页 面 中 的 表单 ,在 "属性 ?面板 中 设置 动作 为 
二 ?php echo $ SendAction; ?> ,方法 为 POST, 添加 邮件 发 送 的 PHP 代码 : 





<?php 

require once('Connections/Maildb.php'); 

$SendAction=$ SERVER['PHP_ SELF']; 

$to=$ POST['receiver']; 

$message=$ POST['content']; 

$from=$ POST['sender']; 

Sheaders= 'From:$from'; 

$now=date("Y-m-d h:i:s"); 

$subject=' [Snow] $ POST['subject']'; 

if (mail ($to,$subject, $message, $headers)) 

{echo "发 送 成 功 "; 
$insertSQL="INSERT INTO YJB (用 户 账号 , 标题 , 内 容 , 时 间 ,， 发 
件 人 ， 收 件 人 ,邮件 标记 ) VALUES ($_SESSION['MM Username']， 
$subject, $message, $now, $from, $to, 2)"; 
mysql_select db($database maildb, $maildb); 
mysql_query ($insertSQL, $maildb) or die(mysql error()); 

jelse { echo "发 送 失 败 ";} 


?> 


八 、 思 考题 


(1) 如 何 实现 邮件 的 回复 功能 ? 应 该 修改 哪些 页 面 的 代码 ? 
(2) 如 果 要 在 发 送 邮 件 中 添加 附件 ,应 该 如 何 对 发 送 邮件 页 面 进行 修改 ? 
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第 9 单元 


全 这 


网 络 论坛 平台 的 建设 与 管理 





网 络 论坛 是 一 种 开放 式 的 信息 交流 空间 。 一 个 简单 的 网 络 论坛 通常 包含 用 户 注册 、 
用 户 登 录用 户 列表 、 发 表 主 题 .主题 列表 .主题 显示 、` 回 复 主 题 .查找 主题 和 删除 主题 等 功 
能 模块 。 这 些 功能 模块 的 实现 与 对 应 的 数据 表 操 作 分 不 开 。 

本 单元 以 网 络 论坛 建设 与 管理 为 例 ,通过 完成 主题 表 (ztb) 的 数据 表 设 计 ， ea 
表 (yhlb. php) 用户 登录 (yhdl. php) 登录 出 错 提示 (dlccts. php) 发表 主 题 (fbzt. php) .主题 
列表 (ztlb. php) 和 主题 显示 (ztxs. php) 六 个 网 页 程序 设计 ,实现 论坛 的 基本 功能 。 


9.1 建立 数据 表 
一 、 实 验 目 的 
学 习 使 用 SQL 语句 创建 数据 表 的 方法 ,提高 编写 和 调试 SQL 语句 的 能 力 。 
`“、 实 验 任务 


在 wssd 数据 库 中 创建 主题 表 (ztb) ,结构 如 表 9-1 所 示 。 
表 91 ztb 表 结 构 设 计 说 明 
































字段 名 类 型 长 度 默认 值 说 明 
8 自 增 值 主键 ,在 PHPMyAdmin 中 选 
We. 中 A_I 列 
标题 Varchar 30 最 多 存储 15 个 汉字 
会 员 账 号 | Char 10 
姓名 Char 10 
主题 册 容 。 | Longtext 全 人 人 比 Char 和 Varchar 更 多 ,可 
主题 日 期 Timestamp CURRENT_TIMESTAMP | 使 用 4B 存储 


圣 、 任务 分 析 


数据 表 设 计 是 实现 网 络 论坛 功能 的 基础 。 网 络 论坛 功能 越 丰富 ,数据 表 就 越 多 。 创 
建 数 据 表 的 方法 有 多 种 ,通过 PHPMyAdmin 可 视 化 数据 库 管理 工具 编写 和 运行 SQL 语 
句 , 可 以 简便 ,快捷 地 完成 任务 。 


四 、 预 备 知识 


CREATE TABLE 语句 创建 表 时 ,在 int 型 字段 后 增加 AUTO_INCREMENT 短语 ， 
设置 字段 为 自 增值 字段 ,可 作为 表 的 主键 。 


五 、 技 能 点 


01) 设计 CREATE TABLE 语句 。 在 SQL 语句 编辑 框 中 输入 语句 ,使 之 满足 任务 
要 求 。 

(2) 运行 CREATE TABLE 语句 。 调 试 CREATE TABLE 语句 ,纠正 错误 和 检查 运 
行 结果 。 


六 、 注 意 事项 


一 个 数据 库 中 的 表 不 能 重 名 , 即 不 能 重复 执行 创建 同一 个 表 的 CREATE TABLE 


语句 。 
七 、 设计 步 又 


(1) 启动 Apache 和 MySQL。 双 击 桌 面 XAMPP-Control 图 标 , 启动 XAMPP 
Control Panel, 分 别 单 击 Apache 和 MySQL 对 应 的 Start 按钮 。 
(2) 启动 PHPMyAdmin。 单 击 MySQL 的 Admin 按钮 ,浏览 器 打开 PHPMyAdmin 
窗口 。 
(3) 新 建 数据 表 。 单 击 数 据 库 名 wssd, 选 择 SQL 选项 卡 , 在 SQL 语句 编辑 框 中 输入 
如 下 语句 : 
CREATE TABLE ztb( 
ztid int (8) NOT NULL AUTO_INCREMENT, 标 题 varchar (30) NOT NULL, 
会 员 账 号 char (10) NOT NULL, 姓 名 char (10) NOT NULL, 主题 内 容 longtext NOT NULL, 
主题 日 期 timestamp NOT NULL DEFAULT CURRENT TIMESTAMP, 
/< 以 增加 记录 时 间 为 默认 值 ,更 新 记录 时 不 刷新 * / 
PRIMARY KEY (ztid)) 
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ENGINE=InnoDB DEFAULT CHARSET= gb2312 


(4) 查看 结果 。 单 击 SQL 语句 编辑 窗口 中 的 “执行 ”按钮 后 ,选择 “结构 ”选项 卡 , 单 
击 ztb 的 “结构 ”, 查 看 表 结构 (如 表 9-1 所 示 )。 


八 、 思 考题 


(1) 如 何 修改 已 经 存在 的 数据 表 结构 ? 
(2) 如 果 主 题 允许 回复 ,如 何 设计 回复 表 结 构 ? 


9.2 论坛 用 户 登 录 网 页 程序 设计 
一 、 实 验 目 的 
通过 “用 户 身份 验证 "的 方法 ,学 习 数 据 验 证 的 网 页 程序 设计 方法 。 
二 、 实验 任 务 


(1) 创建 论坛 目录 bbs。 
(2) 设计 如 图 9-1 所 示 的 论坛 用 户 列表 网 页 程序 yhlb. php。 


ol 


1 
EE 





会 员 帐 号 | 姓名 | mA 账号 | wks 
1101010001 | 郑 卢 然 | elex_chenapublie ee. an | 657807384 
2101010001 | 孙 洪 沽 | ‘sunhtQ163. com | 4mlrazsz 
2101010002 刘 永 刍 | yongfengliuB163 com | 423970282 
2201010001 | 起 咸 才 | zhaoB10Qsobn com |8423886212 | 
2201010002 | 张 君 | Eeijurfsins con en | 1212772 
2201040001 | 宁 劲 松 | ningjinsong8126 con | 15160994 | 


2201040002 | 张波 | aehoasina co en 


图 9-1 论坛 用 户 列表 网 页 














(3) 设计 如 图 9-2 所 示 的 登录 出 错 提示 网 页 程序 dlccts. php。 
(4) 设计 如 图 9-3 所 示 的 论坛 用 户 登录 网 页 程序 yhdl. php。 
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phn 


:#0 EY SE 
二 


怎 的 用 户 各 或 宪 码 异 误 ,元 法 全 对! 








图 9-2 登录 出 错 提示 网 页 








图 9-3 论坛 用 户 登 录 网 页 


三 、 任务 分 析 


用 户 登 录 网 页 程序 将 用 户 登录 信息 与 数据 库 中 的 注册 信息 进行 比 对 ,如 果 信息 一 臻 
则 跳 转 到 发 表 主 题 网 页 程序 ,并 将 用 户 信息 写 人 _SESSION 超 全 局 数组 ,否则 跳 转 到 登录 
出 错 提 示 网 页 程序 。 


四 、 预 备 知 识 


(1) SESSION。 通 过 用 户 唯一 的 标识 存储 在 本 地 的 cookie 中 。 
(2) _SESSION 数组 。PHP 中 的 超 全 局 数组 ,可 用 于 网 页 程序 之 间 的 数据 交互 。 


五 、 技 能 点 


(1) 登录 验证 设计 。 人 恰当 地 使 用 Dreamweaver 的 “用 户 身 份 验证 ”对 象 可 以 简单 、 快 
捷 地 完成 网 页 程序 设计 。 
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(2) 编码 。 只 有 对 数据 库 .PHP 操作 数据 和 网 页 显示 数据 进行 正确 的 编码 ,才能 避 
免 乱码 出 现 。 


六 、 注 意 事项 


在 设计 用 户 登 录 网 页 程序 前 ,应 该 先 设计 登录 出 错 提示 网 页 程序 。 
七 、 设 计 步 又 


1. 创建 论坛 目录 bbs 


(1) 启动 Dreamweaver。 双 击 桌 面 Dreamweaver 图 标 , 单 击 “ 窗 口 ”菜单 一 "工作 区 布 
局 选 框 ? 一 “应 用 程序 开发 人 员 ( 高 级 ) "选项 。 

(2) 新 建 子 目录 。 布 击 “ 文 件 ” 面 板 中 的 “站 点 -wssd” 图 
标 ,选择 “新 建文 件 夹 ” 选 项 ,输入 文件 夹 名 为 bbs。 

(3) 复制 网 页 模板 文件 。 将 第 5 单元 的 5. 2 节 创 建 的 
模板 muban. html 复制 到 D: \wssd\bbs 文件 夹 。 右 击 bbs | 六 外 aa- mw 
文件 夹 中 的 muban. html 文件 ,选择 “编辑 ”一 “ 重 命 名 ” 选 EB-B bbs 
项 ,输入 muban. php 并 按 Enter 键 ,如 图 9-4 所 示 。 BD comeetions 


wssd php 
















C4) 增加 网 页 模板 中 的 代码 。 在 “代码 "视图 下 ，| 5 口 …，. 

muban. php 文件 中 的 开始 位 置 插入 以 下 代码 : ee 
<?php if (!isset ($_SESSION)) session start();?> mi FF 
<?php require once('Connections/wssd.php'); FE 002/S WN (Es] 
mysql_query("SET NAMES 'utf-8°'");?> 图 9-4 网 站 目录 结构 
(5) 调整 网 页 模板 中 的 代码 。 对 网 页 模板 中 的 代码 进 

行 下 列 修改 。 


Q@“2017-04-06” 改 为 : 

<2php echo date ("Y-m-d");?> 
@ Thursday 改 为 : 

< ?php echo date("1")72?> 

@ css/wssd. css 改 为 
../css/wssd.css 

@ images 改 为 : 


../images 
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2. 论坛 会 员 信息 显示 网 页 程序 设计 


(1) 新 建 网 页 。 右 击 “ 文 件 ” 面 板 bbs 文件 夹 中 的 muban. php, 选择“ 编辑 ”一 “复制 ” 
选项 。 布 击 “*muban - 拷贝 . php”, 选 择 “ 编 辑 ”>“ 重 命名 ”选项 ,输入 yhlb 并 按 Enter 键 ， 
编辑 yhlb. php。 

(2) 修改 网 页 中 的 代码 。 在 “代码 ”视图 下 ,进行 如 下 修改 。 

Qa 将 “标题 "两 个 字 改 为 “论坛 用 户 列表 ”。 

Q@ 将 areamain 改 为 areatable。 

@ 删除 一 div class 王 "areatable" 过 与 二 /div 之 之 间 的 文本 ,并 保留 光标 位 置 。 

(3) 记录 集 设 计 。 在 “设计 ”视图 下 , 单 击 * 插 和 人 ”菜单 ~ 数据 对 象 "-~ 记 录 集 ?选项 ， 
按 图 9-5 设计 相关 参数 , 选 定 列 为 会 员 账 号 、 姓 名 、Email 账号 和 QQ 账号 。 


名 称 ; RecordsetYHLB 
连接 ; |wssd 
表格 : [hyb 

列 : 〇 全 部 ”加 碗 定 的 





























图 9-5 “记录 集 " 窗 口 


(4) 单 击 “ 高 级 ”按钮 ,生成 的 Select 语句 如 图 9-6 所 示 。 最 后 单 击 “ 确 定 ” 按 钮 。 





连接 : wssd 
SQL: SELECT 会 员 账 号 ， 姓 名 ，EIAL 了 号 ,0 三 避 一 
[Pon hyb 


















































9-6 “记录 集 ? 对 话 框 
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(5) 显示 记录 集 。 单 击 * 插 入? 莱 单数 据 对 象 "一 ”动态 数据 ”一 ”动态 表格 ”选项 ， 
“数据 集 ? 选 择 RecordsetYHLB,“ 边 框 ” 输 入 0, 单 击 “ 确 定 ” 按 钮 ;在 “设计 ”视图 下 , 单 击 表 
格 中 的 任意 位 置 和 状态 栏 二 table 二 标签 ,“ 属 性 ”窗口 中 的 “类 ”选择 tb。 

(6) 预览 。 按 F12 键 浏览 网 页 (如 图 9-1 所 示 )。 


3. 登录 出 错 提示 网 页 程序 设计 


(1) 新 建 网 页 。 右 击 “ 文 件 ?面板 bbs 文件 夹 中 的 muban. php, 选择“ 编辑 ”一 “复制 ” 
选项 。 右 击 “muban - 拷贝 . php”, 选 择 “ 编 辑 ” 一 “ 重 命 名 ”选项 ,输入 dlccts , 按 Enter 键 ， 
编辑 dlccts. php。 

(2) 网 页 区 块 设计 。 在 “代码 ”视图 下 ,进行 如 下 修改 。 

@ 将 “标题 ”两 字 改 为 “登录 出 错 提 示 ”。 

@ 将 areamain 改 为 areatable。 

(3) 显示 信息 设计 。 将 二 div class 一 "areatable" 盖 与 一 /div 之 之 间 的 文本 改 为 “您 的 
用 户 名 或 密码 错误 ,无 法 登录 !”。 

(4) 预览 。 按 F12 键 浏览 网 页 (如 图 9-2 所 示 )。 

4. 论坛 用 户 登录 网 页 程序 设计 

(1) 新 建 网 页 。 右 击 “ 文 件 ” 面 板 bbs 文件 夹 中 的 muban. php, 选 择 “ 编 辑 ” 一 “复制 ” 
选项 。 布 击 “*muban - 拷贝 .php”, 选 择 “ 编 辑 ” 一 “ 重 命名 ”选项 ,输入 yhdl, 按 Enter 键 , 编 
辑 yhdl. php。 

(2) 网 页 区 块 设计 。 在 “代码 ”视图 下 ,进行 如 下 修改 。 

@ 将 “标题 ?两 字 改 为 “论坛 用 户 登 录 ”。 

@ 将 二 div class 王 "areamain "二 一 /div 之 之 间 的 文本 用 如 下 代码 替换 


<form name="forml" method="POST" action=""> 
<div class="login"> 
账号 :<input type="text" name="userid"/></br> 
密码 : <input type="password" name="password"/></br> 
<p><input name="sub" type="submit" value=" 登 录 "/></p></div></form> 


(3) 登录 验证 设计 。 在 “设计 ”视图 下 , 单 击 “ 插 入 ”菜单 “数据 对 象 >>“ 用 户 身份 验 
证 ”>“ 登 录用 户 ” 选 项 ,设计 结果 如 图 9-7 所 示 , 单 击 “ 确 定 ” 按 钮 。 

(4) SQL 语句 修改 。 在 “代码 ?视图 下 ,进行 下 列 修改 。 

@ 将 “SELECT ' 会 员 账号 ,密码 ' FROM hyb” 改 为 : 

SELECT * FROM hyb 


@ 将 代码 行 *“$ _SESSION['MM_Username'] 二 $loginUsername” 改 为 : 


$row =mysql fetch assoc($LoginRS); 
$_SESSION['MM Userid'] =$row[" 会 员 账 号 "]; 
$_SESSION['MM Username'] =$row[" 姓 名 "]; 
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本 录用 产 


从 表单 著 茹 输入 : | fornl ” 
| 


密码 字段 |pessword 














如 果 登 录 蕊 功 ， 转 到 ;fwssd/bbs/ fbzt_php | 


回转 到 前 一 个 URL ( 如 果 它 存在 ) 
癌 果 登 录 失 风 ， 转 到 : /wssd/bbs/ leets php FT 








基于 以 下 项 限制 访问 : 器 用 户 名 和 密码 
用户 洛 、 密 码 和 访问 级 列 
黎 职 级 到 请 会员 陈 号 














图 9-7 设计 用 户 登录 窗口 


(5) 预览 。 按 F12 键 浏览 网 页 (如 图 9-3 所 示 )。 


八 、 思 考题 


(1) 如 何 设 计 登 录 出 错 原因 提示 网 页 程序 ? 
(2) 如 何 设 计 注销 登录 网 页 程序 ? 


9.3 发 表 主 题 网 页 程序 设计 
一 、 实 验 目 的 
学 习 “ 插 入 记录 表单 向 导 ” 的 使 用 方法 ,简化 插入 记录 的 表单 设计 。 
二 、 实 验 任务 
设计 如 图 9-8 所 示 的 发 表 主题 网 页 程序 fbzt. php, 向 数据 表 ztb 插入 记录 。 
三 、 任 务 分 析 


发 表 主 题 是 网 络 论坛 的 主要 功能 ,将 网 页 输入 的 数据 提交 到 服务 器 ,加 到 对 应 数据 表 
(ztb) 中 。 通 过 “插入 记录 表单 向 导 ” 可 以 简单 ,快捷 地 完成 设计 。 
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MA 


0 


发 表 主 村 


1101010001 





姓名 :| 区 二 寺 
人 王 联 驳 运 车 之 通 》 这 本 书 扩 过 不 机 | 
次 帮 








图 9-8 ”发表 主题 网 页 
、 预 备 知识 


插入 记录 表单 向 导 。 用 Dreamweaver 提供 的 数据 对 象 操作 ,将 表单 与 数据 表 相关 
联 , 完 成 表单 数据 的 提交 操作 , 即 完成 将 表单 中 的 信息 插入 到 对 应 数据 表 的 操作 。 


五 、 技 能 点 


设计 插入 记录 的 表单 。 用 Dreamweaver 的 “插入 记录 表单 向 导 ” 设 计 表单 。 


六 、 注 意 事 项 


(1) 启用 session。 在 使 用 PHP 的 超 全 局 数组 _SESSION 之 前 ,需要 调用 session_start() 
方法 启用 session。 

(2) 数据 默认 值 。 在 数据 库 中 设置 了 主题 日 期 的 默认 值 ,不 需要 在 表单 中 提交 。 

(3) 文本 框 默认 值 。 在 进行 文本 框 设 计时 ,可 将 文本 框 默认 值 设 置 为 变量 名 。 本 例 
中 引用 超 全 局 关联 数组 SESSION 中 的 元 素 , 用 于 显示 用 户 身份 。 


七 、 设 计 步 又 


(1) 新 建 网 页 。 右 击 “ 文 件 ” 面 板 bbs 文件 夹 中 的 muban. php ,选择 “编辑 ”一 “复制 ” 
选项 。 右 击 “muban - 拷贝 . php” ,选择 “编辑 ”一 “ 重 命名 ”选项 ,输入 fbzt, 按 Enter 键 , 编 
辑 fbzt. php。 

(2) 网 页 区 块 设计 。 在 “代码 ”视图 下 ,进行 如 下 修改 。 

Oa 将 “标题 ”两 个 字 改 为 “发 表 主 题 ”, 并 删除 二 div class 王 "areamain" 二 一 /div 二 之 间 
的 文本 。 
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@ 将 “请 登录 ”3 个 字 改 为 : 

<?php echo $_SESSION['MM_ Username'];?> 

(3) 表单 设计 。 光 标定 位 在 二 div class 王 "areamain" 过 之 后 ,在 “设计 ”视图 下 , 单 击 
“插入 ”菜单 一 “数据 对 象 >>“ 插 入 记录 ”一 “插入 记录 表单 向 导 ” 选 项 ,在 图 9-9 中 ,分 别 选 
定 ztid 和 “主题 日 期 "字段 并 按 “ 一 ”按钮 将 其 删除 ,设置 相关 参数 ,并 将 “会 员 账 号 ”的 默认 
值 设 为 : 

<?php echo $_SESSION['MM Userid'] ; ?> 

将 “姓名 ”的 默认 值 设 为 : 

<?php echo $_SESSION['MM Username'] ; ?> 

单 击 “ 确 定 ” 按 钮 关闭 “插入 记录 表单 ”对 话 框 。 在 “设计 ”视图 中 单 击 “ 插 入 记录 ” 按 
钮 ,在 属性 面板 中 ,修改 值 为 “发 表 ”, 单 击 表格 中 的 任意 位 置 和 状态 栏 二 table 二 标签 ,在 
属性 窗口 中 ,类 ?选择 tb。 


插入 后 ， 转 到 : ztlb. php 





要 单 字段 二 | 一 | 














默认 香 - ?php echo $_SESSIONT MN_Usernane ] ; 让 到 





图 9-9 插入 记录 表单 设置 窗口 


(4) 预览 。 按 F12 键 浏览 网 页 (如 图 9-8 所 示 )。 单 击 “ 发 表 ” 按 钮 后 ,浏览 器 跳 转 到 
ztlb 页 面 ,此 时 浏览 器 提示 找 不 到 网 页 (该 页 面 将 在 下 一 个 实验 中 设计 )。 依 次 发 表 3 个 
主题 ,使 用 PHPMyAdmin 查看 ztb 新 增 的 数据 记录 (如 图 9-10 所 示 )。 


ztid 标题 会 呈 账 号 姓名 ”主题 内 容 主题 日 其 
1 推荐 1101010001 郑 尝 然 《互联 网 运营 之 道 》 | 2018-02-07 14:57:02 
图 书 这 本 书 非 党 不错 | 
2 最 新 “1101010001 郑 岩 然 。《 第 一 次 机 器 革命 》 2018-02-07 14:57:53 
医 考 已 等 出 版 





3 转让 1101010001 | 郑 岩 然 ， 《C 竹 序 设计 》 转 让 “2018-02-07 14:58:24 
图 3 


起 修改 人 @ 则 除 层 号 出 





图 9-10 数据 记录 浏览 视图 
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从 < 4 考题 


(1) 如 何 限制 每 位 会 员 发 表 主题 的 时 间 间 隔 ? 
(2) 如 何 限制 每 位 会 员 每 天 发 表 主 题 的 数量 ? 


9.4 主题 列表 网 页 程序 设计 


一 、 实 验 目 的 
充分 利用 “动态 表格 ”, 学 会 显示 数据 的 网 页 程序 设计 方法 。 
二 、 实验 任务 


设计 如 图 9-11 所 示 的 主题 列表 网 页 程序 ztlb. php, 显 示 数 据 表 ztb 中 的 记录 。 


风 汪 禄 访 册 站 未 


Ey A 中 心 币 作 











图 9-11 主题 列表 预览 视图 


三 、 任 务 分 析 
主题 列表 将 展示 已 经 发 表 的 主题 ,通过 单 击 列表 中 的 链接 ,查看 对 应 的 主题 细节 。 
四 、 预 备 知识 


参数 传递 。 将 ztid 作为 链接 的 参数 ,传人 自身 或 男 一 个 PHP 网 页 ,完成 网 页 之 间 的 
数据 交换 。 
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五 、 技 能 点 


设计 显示 数据 的 PHP 网 页 程序 。 用 “动态 表格 "可 以 简单 .快捷 地 设计 网 页 程序 。 
六 、 设 计 步 又 


(1) 新 建 网 页 。 布 击 “ 文 件 " 面 板 bbs 文件 夹 中 的 muban. php, 选择“ 编辑 ”一 “复制 ” 
选项 。 布 击 “*muban 一 拷贝 . php”, 选 择 “ 编 辑 ”>“ 重 命名 ”选项 ,输入 ztlb, 按 Enter 键 ， 
编辑 ztlb. php。 

(2) 网 页 区 块 设计 。 在 “代码 ”视图 中 ,将 “标题 "两 个 字 改 为 “主题 列表 ”,areamain 改 
为 areatable, 删 除 二 div class 王 "areatable" 过 与 二 /div 二 之 间 的 文本 。 

(3) 登录 状态 显示 。 将 “请 登录 ”3 个 字 改 为 下 列 代码 : 


<?php echo $_SESSION['MM Username'];?> 


(4) 记录 集 设计 。 将 光标 定位 在 二 div class 王 "areatable" 二 之 后 ,在 “设计 ”视图 下 ， 
单 击 “ 插 入 ”菜单 一 “数据 对 象 ”“ 记 录 集 "选项 。 在 记录 集 高 级 窗口 中 ,“ 名 称 ”文本 框 输 
入 RecordsetZTLB, 单 击 “ 表 格 ” 左 侧 “ 十 ”按钮 ,选择 ztb, 单 击 SELECT 一 “确定 ”按钮 。 

(5) 显示 记录 和 集 。 单 击 “ 插 入 ”菜单 一 “数据 对 象 ” 一 “动态 数据 ”一 “动态 表格 ”选项 ， 
“数据 集 ” 选 择 RecordsetZTLB,*“ 边 框 ? 输 入 0, 单 击 “ 确 定 ” 按 钮 。 

(6) 删除 列 。 选 择 表 格 主题 内 容 列 ,如 图 9-12 所 示 , 按 Del 键 删除 该 列 。 








右手 入 列 (R) 








图 9-12 选择 表格 列 


(7) 参数 传递 设计 。 选 择 表格 ztid 单元 格 ,输入 “查看 ”, 如 图 9-13 所 示 。 























图 9-13 编辑 单元 格 


选中 表格 RecordsetZTLB. ztid 单元 格 , 单 击 “ 属 性 面板 "链接 右 侧 文件 夹 " 图 标 , 在 
“选择 文件 ”窗口 中 ,设置 内 容 如 图 9-14 所 示 。ztlb 页 面 将 值 传递 给 ztxs (主题 显示 ) 
页 面 。 
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文件 名 轴 : 。 ztxs php 
文件 类 型 [) [所 有 文件 &*) =] 


TRL: Jwssd/bbs/rtxs. php 参数 .，， 
相 x 皇 站 点 根 目录 | /wssa 


在 让 点 定义 中 更 地 圣 这 的 谤 棕 相对 二 




















9-14 选择 文件 设置 窗口 


单 击 “ 参 数 ” 按 钮 “名称” 输入 ztid, 如 图 9-15 所 示 。 


















































图 9-15 参数 设置 窗口 


单 击 “ 值 "文本 框 右 侧 闪电 按钮 ,在 “动态 数据 "窗口, 单 击 ztid, 如 图 9-16 所 示 , 依 次 
单 击 “ 确 定 ” 按 钮 ,关闭 对 话 框 。 




















fe <?php echo $row_RecordsetZTLB[’ x 














图 9-16 动态 数据 设置 窗口 


(8) 表格 样式 。 单 击 表格 中 的 任意 位 置 和 状态 栏 二 table 二 标签 ,属性 “类 ”选择 tb。 
(9) 预览 。 按 Fl12 键 浏览 网 页 (如 图 9-11 所 示 )。 


七 、 思 考题 


(1) 在 网 页 程序 之 间 进 行 数据 交换 有 哪些 方法 ? 
(2) 如 何 设置 网 页 程序 的 日 期 显示 格式 ? 
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9.5 主题 显示 网 页 程序 设计 


一 、 实 验 目的 
学 习 主 题 显示 网 页 程序 的 设计 过 程 ,掌握 动态 表格 的 使 用 方法 。 
二 、 实 验 任务 


设计 如 图 9-17 所 示 的 主题 显示 网 页 程序 ztxs. php。 


i 


rtid| 标题 | 会 员 蝶 号 | 姓名 内 可 主题 日 期 
1 | 推 必 图 1101010001 | 观 冯 | “互生 对 营 夺 淹 ” 这 本 书 夺 | 2016-02-07 





图 9-17 主题 显示 网 页 


三 、 任务 分 析 
接收 到 上 一 网 页 程序 传人 的 ztid, 将 其 作为 查询 条 件 ,查询 对 应 的 主题 信息 。 用 


Dreamweaver 记录 和 集 的 筛选 功能 可 以 快速 地 完成 信息 检索 , 青 用 “动态 表格 ”对 象 可 以 简 
单 、 快 捷 地 设计 网 页 程序 。 


四 、 技能 点 
带 检索 条 件 的 查询 程序 设计 : 用 记录 集 的 筛选 可 以 设计 数据 查询 。 
五 、 注 意 事项 


(1) 记录 集 窗口 。 记 录 集 窗口 有 高 级 和 简单 两 种 视图 。 
(2) 页 面 跳 转 。 通 过 操作 ztlb. php 跳 转 到 ztxs. php ,才能 看 到 对 应 的 效果 。 
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六 、 设 计 步 又 


(1) 新 建 网 页 。 右 击 “ 文 件 ” 面 板 bbs 文件 夹 中 的 muban. php, 选择“ 编辑 ”一 “复制 ” 
选项 。 右 击 “muban 一 拷贝 . php”, 选 择 “ 编 辑 ” 一 “ 重 命 名 ”选项 ,输入 ztxs, 按 Enter 键 ， 
编辑 ztxs. php。 

(2) 网 页 区 块 设计 。 在 “代码 "视图 下 ,将 “标题 "两 个 字 改 为 “主题 显示 ”,areamain 改 
为 areatable, 删 除 二 div class 王 "areatable" 过 与 一 /div 二 之 间 的 文本 。 

(3) 登录 状态 显示 。 将 “请 登录 ”3 个 字 改 为 下 列 代码 : 


<?php echo $_SESSION['MM Username'];?> 


(4) 设计 记录 集 。 将 光标 定位 在 二 div class 一 "areatable" 过 之 后 ,在 “设计 ”视图 下 ， 
单 击 “ 插 入 "菜单 “数据 对 象 >>“ 记 录 集 ”选项 ,设计 结果 如 图 9-18 所 示 , 最 后 单 击 “ 确 
定 ” 按 钮 。 


记录 生 





名称 : RecordsetZT 






































图 9-18 “记录 和 集 ”对 话 框 


(5) 显示 记录 集 。 单 击 “ 插 入 "菜单 >“ 数据 对 象 * 一 “动态 数据 >“ 动态 表格 ”选项 ， 
“数据 集 ” 选 择 RecordsetZT， 边 框 ?输入 0, 单 击 “ 确 定 ” 按 钮 。 

(6) 表格 样式 。 单 击 表格 中 的 任意 位 置 和 状态 栏 二 table 二 标签 ,属性 “类 ”选择 tb。 

(7) 预览 。 按 Ctrl 十 S 键 保 存 文件 ,双击 “文件 "面板 中 的 主题 列表 文件 ztlb. php, 按 
F12 键 预览 (如 图 9-17 所 示 ) , 单 击 查看 列 中 的 序号 ,查看 主题 显示 页 面 效 果 。 


七 、 思 考题 


(1) 如 何 设计 回复 主题 网 页 程序 ? 
(2) 如 何 设计 删除 主题 网 页 程序 ? 
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第 10 单元 


微 信 公 众 号 设计 


微 信和 是 面向 智能 手机 用 户 , 支 持 多 种 通信 运营 商 、 多 种 操作 系统 平台 的 即时 通信 和 软 
件 , 通 过 此 类 软件 可 以 进行 语音 视频 、 图 片 和 文字 的 互动 交流 。 个 人 和 企业 都 可 以 注册 
属于 自己 的 微 信 公 众 号 ,与 指定 用 户 群 进行 收发 文字 、 图 片 和 语音 信息 等 交互 活动 。 

本 单元 以 网 上 书店 微 信 公 众 号 为 例 , 实 际 演练 微 信 公 众 号 的 申请 和 设计 ,并 通过 自 定 
义 菜单 和 网 上 书店 进行 链接 ,使 读者 掌握 微 信 公 众 号 的 分 类 、 功 能 和 设计 技巧 ,提升 用 计 
算 机 技术 实现 移动 网 络 平台 设计 的 能 力 。 


10.1 注册 公众 号 
一 、 实验 目的 
了 解 微 信 公众 号 分 类 ,掌握 微 信 公众 号 的 注册 方法 。 
二 、 实 验 任务 
登录 微 信 公众 平台 网 站 ,用 个 人 身份 证 信息 ,注册 类 型 为 普通 订阅 号 的 微 信 公众 号 


三 、 任务 分 析 


设计 微 信 公众 号 ,首先 需要 登录 微 信 公 众 平台 网 站 完成 注册 。 注 册 前 需要 了 解 微 信 
公众 号 的 种 类 及 功能 ,准备 好 所 需 资料 。 


四 、 预 备 知识 


1. 微 信 公 众 号 分 类 
根据 审核 要 求 和 提供 功能 的 不 同 , 微 信 公众 号 分 为 订阅 号 、 服 务 号 、 企 业 微 信和 小 程 


序 四 大 类 。 

(1) 订阅 号 。 为 媒体 和 个 人 提供 新 的 信息 传播 方式 ,构建 与 读者 之 间 更 好 的 沟通 与 
交流 模式 ,适用 于 个 人 和 组 织 。 

(2) 服务 号 。 给 企业 和 组 织 机 构 提供 强大 的 业务 服务 与 用 户 管理 功能 ,不 适用 于 
个 人 。 

(3) 企业 微 信 。 帮助 企业 和 组 织 机 构 实现 内 部 沟通 和 协同 管理 ,适用 于 企业 、 政 府 、 
事业 单位 或 其 他 组 织 。 

(4) 小 程序 。 是 一 种 连接 微 信用 户 与 服务 内 容 的 方式 ,可 以 在 微 信 内 部 便捷 地 获取 
和 传播 信息 ,适用 于 企业 和 组 织 机 构 。 

其 中 订阅 号 和 服务 号 又 分 为 普通 号 和 认证 号 ,在 功能 和 权限 上 的 区 别 如 表 10-1 






































所 示 。 
表 10-1 订阅 号 和 服务 号 功能 一 览 表 
功能 权限 普通 订阅 号 | 微 信 认证 订阅 号 | 普通 服务 号 | 微 信 认证 服务 号 
消息 直接 显示 在 好 友 对 话 列表 中 Vv V 
消息 显示 在 “订阅 号 "文件 夹 中 V NA 
每 天 可 群发 1 条 消息 V Vv 
每 月 可 群发 4 条 消息 V ~ 
无 限制 群发 
保密 消息 禁止 转发 
关注 时 验证 身份 
基本 消息 接收 /回复 接口 V NA ~V V 
自 定义 菜单 Vv Vv V Vv 
定制 应 用 
高 级 接口 能 力 部 分 支持 V 
微 信 支 付 商户 功能 部 分 支持 ~V 














企业 微 信 覆盖 了 iOS、Android ,Windows 和 Mac 等 操作 系统 平台 , 预 置 了 打卡 .审批 
和 日 报 等 办 公 应 用 ,集成 了 公司 统一 付费 电话 、 视 频 会 议和 企业 邮箱 等 通信 方式 ,可 以 导 
入 和 统一 管理 企业 通信 录 ,是 针对 企业 需求 的 专业 通信 工具 。 

小 程序 是 一 种 不 需要 下 载 安装 即 可 使 用 的 应 用 ,用 户 可 以 通过 扫 码 、 好 友 推 荐 和 微 信 
搜索 等 方式 获得 。 通 过 编写 程序 代码 可 以 实现 快递 教育、 交通 、 和 餐饮 和 旅游 等 领域 的 服 
务 功能 。 小 程序 开发 完成 后 需要 审核 通过 才能 发 布 。 


2. 注册 微 信 公 众 号 
注册 微 信 公众 号 需要 准备 一 些 资料 ,如 表 10-2 所 示 。 


全 为 。 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


表 10-2 注册 准备 资料 























政府 类 型 媒体 类 型 企业 类 型 其 他 组 织 类 型 个 人 类 型 
政府 全 称 组 织 名 称 企业 名 称 组 织 名称 身份 证 名 称 
运营 者 身份 证 名 称 | 组 织 机 构 代 码 营业 执照 注册 号 | 组 织 机 构 代码 身份 证 号 码 
运营 者 身份 证 号 码 | 运营 者 身份 证 名 称 | 企业 对 公 账 户 运营 者 身份 证 名 称 | 手机 号 码 
运营 者 身份 验证 运营 者 身份 证 号 码 | 运营 者 身份 证 名 称 | 运营 者 身份 证 号 码 
运营 者 手机 号 码 运营 者 身份 验证 运营 者 身份 证 号 码 | 运营 者 身份 验证 

运营 者 手机 号 码 运营 者 身份 验证 “| 运营 者 手机 号 码 
运营 者 手机 号 码 














目前 ,个 人 只 能 注册 普通 订阅 号 ,企业 ,政府 .事业 单位 或 其 他 组 织 可 以 注册 所 有 类 型 


的 微 信 公 众 号 。 


五 、 技 能 点 


(1) 账号 激活 。 登 录 微 信 公 众 平台 网 站 ,填写 正确 的 基本 信息 ,使 用 电子 邮箱 完成 账 


号 激活 。 


(2) 类 型 选择 。 根 据 准备 的 材料 ,选择 正确 的 公众 账号 类 型 。 
(3) 身份 验证 。 通 过 扫描 二 维 码 和 获取 手机 短信 验证 码 的 方式 ,完成 身份 验证 。 


六 、 注 意 事 项 


(1) 填写 基本 信息 时 ,使 用 的 电子 邮箱 应 该 未 被 微 信 公 众 平台 或 微 信 开放 平台 注册 


过 ,同时 未 被 个 人 微 信 号 绑 


(2) 邮箱 验证 码 的 有 效 时 间 为 30 分 钟 。 
(3) 同一 身份 证 号 码 、 手 机 号 码 最 多 只 能 注册 2 个 微 信 公 众 号 。 
(4) 信息 登记 时 ,需要 手机 端 微 信 扫描 二 维 码 验 证 ,使 用 的 微 信号 必须 绑 定 了 本 人 的 


银行 卡 。 


(5) 信息 登记 时 ,需要 手机 短信 验证 。 
(6) 注册 成 功 后 , 微 信 公 众 号 类 型 无 法 更 改 。 


七 、 设计 步 又 


定 ; 密 码 由 字母 ,数字 或 英文 符号 组 成 ,最 短 8 位 ,区 分 大 小 写 。 


(1) 进入 微 信 公众 号 注册 窗口 。 双 击 桌面 "浏览 器 ”图标 ,在 地 址 栏 输入 https:// 
mp. weixin. qq. com, 单 击 网 页 右上 角 “ 立 即 注册 ”链接 ,在 注册 ”网 页 中 单 击 订阅 号 ,浏览 
器 打开 “基本 信息 ”网 页 。 

(2) 填写 基本 信息 。 输 入 邮箱 地 址 并 激活 ,输入 邮箱 验证 码 、 密 码 和 确认 密码 ,选择 “我 
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同意 并 遵守 《 微 信 公众 平台 服务 协议 ”, 单 击 “ 注 册 ” 按 钮 ,浏览 器 打开 “选择 类 型 ”网 页 。 

(3) 选择 注册 地 。 选 择 “ 中 国内 地 ”, 单 击 “ 确 定 ” 按 钮 。 

(4) 选择 账号 类 型 。 单 击 “ 订 阅 号 "下方 “选择 并 继续 ”链接 。 

(5) 信息 登记 。 单 击 “ 主 体 类 型 "下 方 的 “个 人 ”按钮 ,填写 姓名 和 身份 证 号 码 信 息 ; 打 
开 手 机 微 信和 应 用 程序 , 单 击 屏 幕 上 方 “十 ”按钮 ~“ 扫 一 扫 ”, 将 取景 框 对 准 二 维 码 图 片 , 单 
击 “我 确认 并 遵从 协议 ”按钮 ,完成 管理 员 身 份 验 证 ;填写 管理 员 手 机 号 码 相关 信息 , 单 击 
“获取 验证 码 ” 按 钮 ,在 “短信 验证 码 ” 文 本 框 输入 手机 收 到 的 验证 码 , 单 击 “ 继 续 ” 按 钮 , 浏 
览 器 打开 “提示 ”网 页 , 单 击 “ 确 定 ” 按 钮 ,浏览 器 打开 “公众 号 信息 ”网 页 。 

(6) 填写 微 信 公众 号 信息 。 填 写 账号 名 称 、 功 能 介绍 和 运营 地 区 信息 , 单 击 “ 完 成 ” 按 
钮 , 微 信 公 众 号 注册 完成 。 


八 、 思 考题 


(1) 微 信 公 众 号 和 个 人 微 信 号 有 什么 区 别 ? 
(2) 不 同类 型 的 微 信 公 众 号 有 什么 区 别 ? 


10.2 基本 设置 


一 、 实 验 目 的 


充分 利用 微 信 公众 管理 平台 ,学 习 微 信 公 众 号 头像 名 称 和 微 信号 的 设置 方法 ,掌握 关 
注 微 信 公 众 号 的 方法 。 


二 、 实验 任 务 
(1) 上 传 一 张 与 微 信 公众 号 内 容 相 关 的 图 片 ,将 图 片 设置 为 微 信 公众 号 头像 。 
(2) 设置 微 信号 名 称 为 网 上 书店 。 
(3) 下 载 二 维 码 图 片 ,通过 扫描 二 维 码 ,关注 微 信 公众 号 。 

三 、 任 务 分 析 


完成 实验 任务 (1) 和 任务 (2) 需 要 使 用 微 信 公 众 管 理 平台 ,完成 任务 (3) 需 要 使 用 手机 
端 微 信和 应 用 程序 “ 扫 一 扫 ” 功 能 。 


、 预 备 知识 


(1) 微 信 公众 管理 平台 。 用 户 通过 链接 地 址 https://mp. weixin. qq. com 登录 微 信 
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公众 管理 平台 ,可 实现 对 微 信 公 众 号 进行 管理 。 界 面 分 为 消息 区 .导航 区 、 基 本 信息 显示 
区 和 系统 公告 区 ,如 图 10-1 所 示 。 
导航 区 基本 信息 显示 区 系统 公告 区 消息 区 

| 


下 -公众 平台 四 四 | a 
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口 Ss 各 全 公众 平台 推 新 版 客 用 功能 
消息 等 理 。。。 元 信 醒 件 发 “设备 接收 贡 信 息 。 “设备 标 从 板 ”等 新 特性 


用 广 和 理 
竹 信 公众 平台 关于 处 理 转 发 全 钱 、 岂 分 后 本 类 行为 的 公告 
公众 号 援 各 天 导 改版 ,可 以 自 定 义 运 择 权限 援 各 给 第 二 方 平台 
二 推广 
FE 竹 信 网 页 设计 样式 库 发 布 
流量 主 微 信 公 众 平台 关于 整 邓 冯 用 喜 邓 接口 和 楼板 沪 息 接口 行为 的 公告 
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用 户 分 析 公众 平台 发 布 吏 信 web 开发 者 工具 


图 10-1 微 信 公众 管理 平台 界面 图 


(2) 微 信 公 众 号 头像 。 是 手机 端 微 信 应 用 程序 显示 的 微 信 公 众 号 图 片 。 通 过 头像 可 
以 吸引 更 多 粉丝 ,在 众多 微 信 公 众 号 中 获得 更 高 的 辨识 度 。 

(3) 微 信 公 众 号 二 维 码 。 二 维 码 可 以 在 屏幕 上 显示 ,也 可 以 打印 ,是 微 信 公 众 号 推广 
的 重要 工具 。 扫 描 二 维 码 可 以 关注 微 信 公众 号 。 

(4) 微 信 公 众 号 安全 。 除 采用 用 户 名 和 密码 校 验 外 ,还 采用 微 信 号 与 二 维 码 绑 定 验 
证 的 方式 。 在 登录 微 信 公 众 平台 时 ,需要 使 用 绑 定 的 管理 员 微 信号 进行 二 维 码 扫描 。 其 
他 微 信 号 扫描 三 维 码 后 ,可 以 提交 操作 申请 ,系统 会 将 申请 发 送 至 管理 员 的 微 信号 进行 


五 、 技 能 点 


(1) 头像 。 准 备 一 张 合 适 的 图 片 ,设置 微 信 公众 号 头像 。 

(2) 微 信号 。 根 据 微 信 公 众 号 的 内 容 , 设 置 合适 的 微 信号 。 

(3) 二 维 码 。 使 用 微 信 公众 管理 平台 ,下 载 微 信 公众 号 的 二 维 码 图 片 ,以 便 推 广 时 使 用 。 
(4) 关注 微 信 公 众 号 。 使 用 手机 端 微 信 应 用 程序 扫描 二 维 码 ,关注 微 信 公 众 号 。 
(5) 被 用 户 关注 时 称 为 公众 号 ,管理 平台 设置 时 称 为 公众 账号 。 


六 、 注 意 事 项 


(1) 微 信 公 众 号 可 以 通过 公众 号 名 称 或 微 信号 进行 搜索 .关注 ,也 可 以 扫描 二 维 码 直 


第 人 0 单元 ” 激 信 公众 号 设计 (@) 


18) 


(2) 微 信 公 众 号 名 称 、 微 信号 要 便于 用 户 搜索 和 记忆 。 微 信 公众 号 名 称 和 微 信 号 具 
有 排他 性 ,不 能 重复 也 有 修改 次 数 限制 。 
(3) 修改 后 的 头像 需要 经 过 微 信 团队 审核 才能 生效 。 


七 、 设计 步 又 
1. 设置 微 信 公众 号 头像 


(1) 图 片 素材 准备 。 准 备 一 张 与 微 信 公众 号 主题 相关 的 图 片 ,图 片 格式 可 以 为 bmp、 
jpeg jpg 或 gif, 文 件 大 小 不 超过 2MB。 

(2) 进入 设置 窗口 。 双 击 桌面 “浏览 器 "图标 ,在 地 址 栏 输入 https://mp. weixin. qq. 
com, 打 开 微 信 公 众 平台 网 站 登录 网 页 ,输入 用 户 名 和 密码 , 单 击 “ 登 录 ” 按 钮 ,进入 微 信 公 
众 管理 平台 ; 单 击 网 页 左 侧 “ 公 众 号 设置 "一 “账号 详情 "链接 ,进入 信息 设置 界面 。 

(3) 上 传 头像 图 片 。 单 击 “ 修 改 头 人像” 链接 ,在 “修改 头像 "网 页 单 击 “ 选 择 图 片 ”按钮 ， 
在 “打开 ”对 话 框 中 选中 准备 好 的 图 片 , 单 击 “ 打 开 ” 按 钮 ,网 页 自动 上 传 图 片 。 

(4) 设置 头像 。 在 图 片 编辑 框 中 通过 尺寸 控 点 调整 图 片 显示 区 域 和 大 小 ,如 图 10-2 








图 10-2 ” 微 信 公众 号 头像 设置 图 


2. 设置 微 信 号 名 称 

(1) 进入 设置 窗口 。 单 击 网 页 左 侧 “ 公 众 号 设置 "一 网 页 上 方 “账号 详情 ”链接 ,进入 
信息 设置 界面 。 

(2) 设置 名 称 。 单 击 微 信号 右 侧 “设置 "链接 ,在 “设置 微 信和 号" 页面 用 管理 员 微 信号 
扫描 二 维 码 通过 验证 ,在 文本 框 中 输入 微 信号 , 单 击 “ 检 测 ” 按 钮 ,车 系统 显示 “ 微 信号 可 
用 ”, 则 表示 通过 检测 , 单 击 “ 下 一 步 " 和 “完成 ”按钮 。 

3. 下 载 二 维 码 图 片 , 关 注 微 信 公 众 号 


(1) 进入 设置 窗口 。 单 击 “ 公 众 号 设置 "和 “账号 详情 "链接 ,进入 信息 设置 界面 。 
(2) 下 载 二 维 码 图 片 。 单 击 二 维 码 图 片 ,在 “更 多 尺寸” 页 面 , 单 击 二 维 码 边 长 为 gcm 
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的 “下 载 链接 ”, 保 存 二 维 码 图 片 到 本 地 计算 机 。 

(3) 关注 微 信 公 众 号 。 在 本 地 计算 机 打开 下 载 的 二 维 码 图 片 ,打开 手机 端 微 信 应 用 
程序 , 单 击 手机 屏幕 上 方 “十 ”按钮 和 “ 扫 一 扫 ” 菜 单项 ,将 取景 框 对 准 计算 机 屏幕 上 的 二 维 
码 图 片 , 单 击 手机 屏幕 上 “关注 ”按钮 ,成 为 该 公众 号 粉丝 。 


八 、 思 考题 


(1) 如 何 搜索 并 关注 微 信 公 众 号 ? 
(2) 为 保证 微 信 公 众 号 的 信息 安全 ,需要 注意 哪些 问题 ? 


10.3 素材 管理 


一 、 实 验 目的 
掌握 上 传 .管理 和 发 送 多 媒体 素材 的 方法 。 
二 、 实 验 任 务 


(1) 上 传 5 张 图 片 作 为 微 信 公众 号 消息 素材 。 
(2) 编辑 并 预览 一 条 图 文 消息 。 


三 , 任务 分 析 


两 个 实验 任务 都 需要 了 解 微 信 公众 号 支持 的 素材 类 型 ,同时 准备 相应 素材 。 


四 、 预 备 知识 


(1) 素材 库 。 素 材 是 微 信 公众 号 向 粉丝 推送 的 信息 材料 ,在 微 信 公 众 管理 平台 中 可 
以 建立 并 管理 图 文 消息 库 、 图 片 库 、 语 音 库 和 视频 库 。 

(2) 图 文 消息 。 图 文 消息 是 微 信 公 众 号 常用 的 信息 发 布 形式 ,由 图 片 .标题 \ 作 者 、 摘 
要 、 正 文 和 原文 链接 组 成 。 图 文 消息 的 标题 限 为 64 个 汉字 ,作者 限 为 8 个 汉字 ,摘要 限 为 
120 个 汉字 ,正文 限 为 50 000 个 汉字 。 粉 丝 在 阅读 图 文 消息 时 . 单 击 “ 阅 读 原 文 " 可 跳 转 到 
链接 页 面 。 


五 、 技 能 点 


(1) 图 片上 传 。 准 备 合适 的 图 片 ,通过 微 信 公 众 管理 平台 上 传 到 图 片 库 。 
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(2) 编辑 微 图 文 消息 。 使 用 素材 库 中 的 素材 ,编辑 图 文 消息 并 进行 预览 。 
六 、 注 意 事项 


(1) 图 片 素材 。 支 持 bmp png jpeg ,jpg 和 gif 等 格式 ,文件 大 小 不 超过 5MB。 

(2) 语音 素材 。 支 持 mp3、wma、wav 和 amr 等 格式 ,文件 大 小 不 超过 5MB ,时 长 不 
超过 60s 。 

(3) 视频 素材 。 支 持 rm、rmvb、wmv、avi.mpg、mpeg 和 mp4 等 格式 ,文件 大 小 不 超 
过 20MB。 


七 、 设 计 步 又 


1. 上 传 图 片 素材 


(1) 图 片 素材 准备 。 准 备 5 张 尺寸 为 900 像素 X500 像素 的 图 片 。 

(2) 进入 上 传 窗口 。 双 击 桌 面 “ 浏 览 器 "图标, 地 址 输入 https://mp. weixin. qq. 
com, 输 入 用 户 名 和 密码 , 单 击 “ 登 录 ” 按 钮 ,进入 微 信 公 众 管理 平台 。 单 击 “ 素 材 管理 ”一 
“图 片 ” 链 接 和 “上 传 "按钮 ,打开 图 片上 传 界面 。 

(3) 上 传 图 片 。 在 “打开 ”对 话 框 中 选择 图 片 素 四 版 福 信息 
材 , 单 击 “ 打 开 ” 按 钮 。 


2. 编辑 图 文 消息 


(1) 进入 编辑 窗口 。 单 击 “ 素 材 管理 ”>“ 图 文 消 
息 ” 链 接 和 “新 建 图 文 素材 "按钮 ,打开 图 文 消息 编辑 
界面 。 

(2) 输入 图 文 信息 。 输 入 “标题 "为 “出 版 社 信 
息 ”,“ 作 者 "为 “管理 员 ”",“ 正 文 "消息 如 图 10-3 所 示 ， 
单 击 “ 从 图 片 库 选 择 ” 按 钮 ,选择 封面 图 片 。 

(3) 预览 图 文 消息 。 单 击 “ 预 览 ” 按 钮 在 浏览 器 中 9 全 机 全 下 
预览 , 单 击发 送 到 手机 预览 "输入 个 人 微 信号 ,用 手 
机 端 微 信 应 用 程序 可 以 预览 图 文 消息 。 


八 、 思 考题 


(1) 如 何 对 图 片 素材 进行 预 处 理 ? 
(2) 如 何 编辑 图 文 消息 使 其 更 加 美观 ? 





管理 员 


: 04 ”出 版 社 : 高 等 教育 出 版 社 
: 111 出 版 社 : 机 械 工业 出 版 社 
: 115 出 版 社 : 人 民 邮 电 出 版 社 
出 版 社 : 电子 工业 出 版 社 
: 302 出 版 社 : 清华 大 学 出 版 社 
: 5049 出 版 社 : 中 国 全 禹 出 版 社 
; 5086 出 版 社 ; 中 信 出 版 社 
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10.4 消息 推送 


一 、 实 验 目的 
了 解 微 信 公 众 号 消息 类 型 ,掌握 消息 推送 方法 。 
二 、 实 验 任务 


(1) 设置 群发 图 文 消息 ,通过 手机 端 微 信 应 用 程序 查看 。 
(2) 设置 被 关注 回复 ,通过 手机 端 徽 信 应 用 程序 查看 。 
(3) 设置 关键 词 回复 ,通过 手机 端 微 信 应 用 程序 查看 。 


三 、 任 务 分 析 


消息 推送 是 微 信 公众 号 与 用 户 交互 的 主要 手段 之 一 ,上 述 3 个 任务 都 需要 使 用 微 信 
公众 管理 平台 进行 设置 ,并 通过 手机 端 微 信和 应 用 程序 进行 测试 。 


四 、 预 备 知识 


(1) 群发 。 微 信和 公众 号 以 一 对 多 的 模式 发 送 消 息 ,接收 面 较 广 。 群 发 信息 可 以 为 文 
字 , 语 音 、 图 片 、 视 频 和 图 文 消息 。 只 能 向 微 信 公 众 号 的 粉丝 群发 ,人 数 没有 限制 。 群 发 
时 ,可 对 粉丝 按 组 .性别 和 所 在 地 区 进行 筛选 。 

(2) 自动 回复 。 微 信 公 众 号 与 粉丝 交互 的 主要 形式 。 当 粉丝 的 行为 符合 自动 回复 规 
则 时 ,会 收 到 自动 回复 的 消息 。 自 动 回 复 包含 “被 关注 回复 “关键 词 回复 "和 “ 收 到 消息 回 
复 " 等 功能 ,回复 内 容 可 以 是 文字 、 语 音 、 图 片 和 视频 。 

(3) 被 关注 回复 。 用 户 关注 微 信 公 众 号 后 系统 自动 推送 给 用 户 。 

(4) 关键 词 回复 。 当 粉丝 发 送 的 信息 满足 设置 的 匹配 规则 时 ,系统 自动 回复 。 通 
过 微 信 公众 管理 平台 可 为 一 个 微 信 公 众 号 设置 200 条 回复 规则 ,每 条 规则 可 设置 10 个 
关键 字 和 5 条 回复 。 关 键 字 的 匹配 规则 分 为 全 匹配 和 半 匹 配 。 全 匹配 规则 是 当 粉 丝 推 
送 的 内 容 与 设置 的 关键 字 完 全 一 致 时 触发 回复 。 半 匹配 规则 是 当 粉 丝 推送 的 内 容 包 
含 设置 的 完整 关键 字 时 触发 回复 。 回 复 规 则 可 设置 为 “回复 全 部 ?或 “随机 回复 一 条 ”。 
当 设 置 为 “回复 全 部 ”, 系 统 会 将 本 关键 字 下 的 所 有 回复 内 容 全 部 发 送 ,否则 只 随机 发 
送 其 中 一 条 。 

(5) 收 到 消息 回复 。 收 到 粉丝 发 送 消息 时 ,触发 回复 。 只 能 设置 一 条 回复 信息 。 
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五 、 技 能 点 


(1) 设置 群发 。 使 得 消息 能 获得 接收 面 最 广 的 推送 。 
(2) 设置 收 到 消息 回复 和 关键 词 回 复 。 能 实现 微 信 公 众 号 的 自动 问答 功能 。 


六 、 注 意 事 项 


群发 限制 。 普 通 订阅 号 和 认证 订阅 号 每 天 ( 按 自 然 天 ) 可 群发 一 条 消息 ,普通 服务 号 
和 认证 服务 号 每 月 ( 按 自 然 月 ) 可 群发 4 条 消息 。 


七 、 设 计 步 又 


1. 设置 群发 图 文 消 息 


(1) 进入 群发 窗口 。 双 击 桌面 “浏览 器 ?图标 ,地址 输入 https://mp. weixin. qq. com, 输 
和 用户 名 和 密码 , 单 击 “ 登 录 ” 按 钮 ,进入 微 信 公 众 管理 平台 ; 单 击 “ 新 建 群发 信息 ”链接 , 打 
开 群 发 信息 编辑 界面 。 

(2) 群发 消息 。 选 择 “ 群 发 对 象 " 下 拉 列 表 为 “全 部 "性别 ?下拉 列 表 为 “全 部 ”和 群 
发 地 区 ”下 拉 列 表 为 “全 部 ”, 单 击 “ 图 文 消息 ”一 “从 素材 库 中 选择 ”链接 ,选择 已 编辑 的 图 
文 消息 , 单 击 “ 确 定 ”>“ 群 发 "按钮 ,使 用 管理 员 微 信 扫 码 验 证 ,群发 图 文 信息 。 

(3) 查看 消息 。 通 过 手机 端 微 信 应 用 程序 查看 群发 消息 。 


2. 设置 被 关注 回复 


(1) 进入 编辑 窗口 。 单 击 网 页 中 的 “自动 回复 ”一 “被 关注 回复 ”链接 ,打开 被 添加 自 
动 回复 信息 编辑 界面 。 

(2) 输入 回复 信息 。 单 击 “ 文 字 ” 链 接 , 输 入 文字 为 “欢迎 关注 网 上 书店 微 信 公 众 号 ， 
我 们 将 为 您 提供 最 新 的 图 书 资讯 ”, 单 击 “保存 ”按钮 。 

(3) 查看 信息 。 使 用 手机 重新 关注 微 信 公 众 号 ,查看 自动 回复 消息 。 


3. 设置 关键 词 回复 


(1) 进入 编辑 窗口 。 单 击 网 页 的 “自动 回复 ”>“ 关 键 词 回复 ”链接 ,打开 关键 词 回 复 
信息 编辑 界面 。 

(2) 设置 回复 。 单 击 “ 添 加 回复 ”按钮 ,输入 “规则 名 称 ” 为 规则 1, 选 择 “ 全 匹配 ”“ 输 
和 信 关 键 字 ”文本 框 添 加 “销售 电话 ”; 单 击 “ 十 ”按钮 ;选择 “全 匹配 ”,“ 输 入 关键 字 ” 文 本 框 添 
加 “联系 方式 ”; 单 击 回复 内 容 后 “十 ”>“ 文 字 ” 按 钮 “添加 回复 文字 ”文本 框 输 入 为 “座机 
85168162”, 单 击 “ 确 定 ” 按 钮 ,回复 方式 选择 “随机 回复 一 条 ”, 单 击 “ 保 存 ” 按 钮 。 

(3) 查看 信息 。 使 用 手机 端 微 信 应 用 程序 向 微 信 公 众 号 依次 发 送信 息 : 销售 电话 和 
联系 方式 ,查看 自动 回复 消息 情况 。 
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八 、 4 日 考题 


(1) 如 何 通过 群发 图 文 消 息 提高 用 户 活跃 度 ? 
(2) 如 何 通过 设置 多 关键 字 实 现 网 上 书店 自动 问答 系统 ? 


10.5 自 定义 菜单 开发 
一 、 实 验 目的 
了 解 程序 菜单 的 基础 知识 ,掌握 微 信 公 众 号 菜单 设置 。 
二 、 实 验 任务 


(1) 设置 包含 “出 版 社交 编码 查询 “图书 六 图 书信 息 交 员工 ”和 “员工 信息 ?菜单 项 的 
自 定义 菜单 。 
(2) 设置 “编码 查询 ”菜单 项 的 页 面 跳 转 功 能 。 


三 、 任务 分 析 


菜单 是 微 信 公众 号 和 粉丝 交互 最 直观 、 灵 活 的 形式 。 通 过 单 击 菜单 项 完成 某 种 动作 ， 
如 收发 消息 和 页 面 跳 转 。 用 菜单 页 面 跳 转 功 能 ,将 微 信 公 众 号 与 已 有 的 网 站 关联 起 来 , 实 
现 网 站 与 移动 应 用 的 无 缝 链接。 两 个 任务 都 需要 使 用 微 信 公 众 管 理 平台 进行 设置 ,并 通 
过 手机 端 微 信 应 用 程序 进行 测试 。 


四 、 预 备 知识 


(1) 菜单 。 自 定义 菜单 出 现在 微 信和 界面 底部 。 一 个 微 信 公 众 号 可 创建 3 个 一 级 菜单 
项 ,每 个 一 级 菜单 项 下 可 创建 5 个 二 级 菜单 项 。 一 级 菜单 项 名 称 不 多 于 4 个 汉字 或 8 个 
字母 ,二 级 菜单 项 名 称 不 多 于 8 个 汉字 或 16 个 字母 。 

(2) 发 送信 息 。 信 息 类 型 包括 文字 、 图 片 、 语 音 、 视 频 和 图 文 消息 。 不 同类 型 的 微 信 
公众 号 自 定义 菜单 的 功能 如 表 10-3 所 示 。 

(3) 跳 转 到 网 页 。 普 通 订阅 号 可 选择 图 文 消息 作为 跳 转 对 象 , 认 证 订阅 号 和 服务 号 
可 跳 转 到 外 部 链接 。 
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表 10-3 自 定义 菜单 功能 


























动作 类 型 功能 类 型 普通 订阅 号 | 微 信 认 证 订阅 号 | 普通 服务 号 | 微 信 认 证 服务 号 
纯 文字 V V V 
纯 图 片 V V V V 
发 送信 息 纯 语音 NA NA V V 
纯 视 频 V V V ~ 
图 文 消息 V Vv V ~ 
二 古语 外 部 链接 NA V V 
图 文 消息 V NA V V 
开发 者 模式 | 开发 者 模式 NA V Vv V 

















五 、 技 能 点 


(1) 设置 菜单 。 通 过 微 信 公 众 管理 平台 ,可 以 添加 一 级 菜单 和 二 级 菜单 。 
(2) 页 面 跳 转 。 通 过 图 文 消息 的 原文 链接 ,实现 普通 订阅 号 的 页 面 跳 转 。 


六 、 注 意 事项 
菜单 发 布 。 自 定义 菜单 发 布 后 ,手机 端 微 信 应 用 程序 在 24 小 时 后 更 新 显示 。 
七 、 设计 步骤 


1. 设置 自 定义 菜单 


(1) 编辑 菜单 。 双 击 桌 面 “浏览 器 ”图标 ,地 址 输入 https://mp. weixin. qq. com, 输 
入 用 户 名 和 密码 , 单 击 “ 登 录 ” 按 钮 ,进入 微 信 公 众 管理 平台 , 单 击 “ 自 定义 菜单 "导航 链接 ， 
打开 菜单 编辑 界面 。 

(2) 添加 菜单 项 。 单 击 “ 添 加 菜单 ”按钮 ,输入 “菜单 名 称 ” 为 出 版 社 。 单 击 “ 出 版 社 ” 
菜单 项 上 方 “ 十 ”按钮 ,输入 “ 子 菜 单 名 称 ” 为 编码 查询 , 子 菜单 内 容 选 择 “ 发 送 消 息 ”, 单 击 
“图 文 消息 ”>“ 从 素材 库 中 选择 ”, 选择 已 编辑 的 “出 版 社 信息 ”图 文 消息 , 单 击 “ 确 定 ” 一 
“出 版 社 ” 右 侧 * 十 "按钮 ;用 同样 方法 设计 “图 书 ” 菜 单项 及 其 二 级 菜单 “图 书信 息 ”“ 员 工 ” 
菜单 项 及 其 二 级 菜单 “员工 信息 ”, 如 图 10-4 所 示 。 

(3) 预览 菜单 。 单 击 “ 预 览 ” 按 钮 ,在 浏览 器 中 预览 菜单 效果 。 

(4) 发 布 菜 单 。 单 击 “ 保 存 并 发 布 按 钮 ,发 布 菜单 ,使 用 手机 微 信 预 览 。 


2. 设置 菜单 页 面 跳 转 
(1) 修改 图 文 消息 。 打 开 10. 3 节 任 务 (2) 中 制作 的 “出 版 社 信息 ” 图 文 消息 , 单 击 “ 原 
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文 链接 ” 复 选 框 ,在 文本 框 中 输入 http://192. 168. 0. 1/cbslb. php; 单 击 “ 保 存 ” 按 钮 。 其 
中 192. 168.0.1 是 网 上 书店 网 站 IP 地址 ,cbslb. php 是 显示 出 版 社 列表 的 网 页 。 

(2) 查看 菜单 。 使 用 手机 端 微 信 应 用 程序 查看 微 信 公 众 号 编码 查询 菜单 ,在 打开 页 
面 中 单 击 “ 阅 读 原文 ”。 











十 


图 10-4 菜单 设置 图 

















八 、 思 考题 


(1) 微 信 公 众 号 菜单 和 其 他 应 用 程序 菜单 在 功能 上 有 什么 区 别 ? 
(2) 如 何 结 合 网 上 书店 网 站 ,设计 功能 完善 的 网 上 书店 微 信 公众 号 ? 
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样式 文件 WSSD. CSS 中 的 代码 


@charset "utf-8"; 
/* CSS Document */ 
* {margin:0; padding:0;} 
.bg { background:#fefcf5; /* 一 些 不 支持 背景 渐变 的 浏览 器 * / 
background:-moz-linear-gradient (top, rgba (254, 252, 245, 1), rgba (255, 255, 
2555 WIF 
background:- webkit-gradient (linear, 0 0, 0 bottom, from(rgba(250, 230, 159, 1)), 
to (rgba (255, 255, 255, 1))); 
background:-o- linear- gradient (top, rgba (254, 252, 245, 1), rgba (255, 255, 
255, 1)); 


background-attachment :fixed;} 


.wrap{width:900px;margin:0 auto;} 
#header { width: 100% ;min-width: 1000px;height: 30px;line-height: 30px; 
background: #E65511 ;font- size: 14px;border-bottom: lpx solid #999; 


text-align: center;} 


-header-tl {float: left;margin- left: 50px;} 

.header-t23 {float: left;margin- left: 50px;} 

.logo{margin-bottom:10px;} 

-area{margin-bottom:10px; border:2px solid #587F1lE;border- radius:Spx;} 

.areatitle {height:40px; line-height:40px;text-align:center;color:#fff; 
background- color:#587F1E;} 


.areamain{height :180px;text-align: center;} 

.areatable {text - align: center; overflow: hidden; margin - top: Spx; margin - 
bottom: Spx;} 

-link ul, .link li{list-style:none; padding:0;margin:0;} 

-link li{float:left;margin-right:1l5px;margin-bottom:1l5px;margin- top: Spx;text 
-align:center;} 

.link li.last{margin-right:0;} 

link 1i a{fborder- radius:5px;display:block;width:290px;height:50px; 


background- color:#EFE9B9; line-height:50px; overflow:hidden; } 


. footer { clear: both; width: 100%; min - width: 1000px; height: 80px; line - 
height: 30px; 
background: #E65511;font- size:14px;border-bottom: lpx solid #999; 
text-align: center;} 


.detail {margin-bottom:10px;} 

.detail .do{height:500px;background- color:#EFE9B9;margin- bottom:10px;border 

-radius:S5px;} 

.detail .form{height :200px;background-color:#587F1lE;border- radius:S5px;} 

.login {padding- top: 10px;} 

.loginp {margin-bottom: 10px;} 

login p input {padding- left: 1l0px;padding-right: 10px;border: 0; height: 36px; 
line- height: 36px; background- color: rgba (255, 255, 255, .85); 
width: 200px; 


box- shadow: Opx Opx Spx #ccc inset;display:block;margin:auto;} 


.login p button {display: block; width: 136px; height: 36px; background - color: 
#165079; 
border: 0;margin: 0; padding: 0;color: #fff;font- size: 16px; 


border-radius: 5px;margin:auto;} 


.logina {font-size: 16px;color: #333;} 
.login p a:hover {text-decoration: underline;} 
table.tb { font- family: 宋体 , verdana, arial, sans- serif; font- size: 14px; color: 
#333333; 
border-width: lpx;border-color: #999999;border-collapse: collapse; 
margin:0 auto;text-align: center;} 
table.tb th { background:#b5cfd2 ; border-width: lpx; padding: 8px; 
border- style: solid;border-color: #999999;} 
table.tb td { background:#dcddc0 ;border-width: lpx;padding: 8px; 
border- style: solid;border-color: #999999; 
</style> 
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CA 
i 日 
主教 材 习 题解 答 
B.1 第 1 章 习题 解答 
一 、 填空 题 
1. 集中 式 ”@ 桌面 应 用 @ 分 布 式 ”@ 网 络 应 用 
2. @ 客户 /服务 器 @ C/S 加 浏览 器 /服务 器 ”@ B/S 
3. @ 静态 ”@ 动态 脚本 语言 @ 数据 库 
4. 网 站 服务 器 ”@ 客户 端 浏览 器 ”@ 超 文 本 传输 协议 
5. OD Linux @ Apache @ MySQL ©@® PHP 


6. DO HTML @ CSS @ 客户 端 脚本 

7. © httpd. conf ©@ my.ini 

8. @ 修改 访问 网 址 ”@ 修改 服务 器 端口 号 ”@ 修改 认证 方法 
9. @ HTML ©® CsS 

10. @ Start ©@ Config ©@ Admin 





二 、 单 选 题 

lB 必 记 3. D 4. B 5. A 6 D 
8. A $B io; C i Ce 

三 、 多 选 题 


1l. CDEF 2. CDEF 3. BCEF 4. ACDE 5. CE 6. CD 
8. BEF 


B.2 第 2 章 习 题解 答 


一 、 填空 题 
1. @ 规范 化 ”@ 抽象 化 ”@ 数字 化 ”@ 特征 


2. @ 有 组 织 四 结构 化 ”@ 相关 联 @ 事务 特征 ”@ 数据 表 | 表 

@ 主 关键 字 | 主键 | 主 码 @ 关联 | 联系 | 关系 

3. @ 逻辑 设计 @ 物理 设计 @ 需求 分 析 @ 概念 设计 

4. 学生, 专业 ”@ 张 明 宇 、 经 济 学 ”@ 学 号 、 姓 名 ,专业 码 、 专 业 名 称 

@ 22159901,. 张 明 宇 .020101 经济 学 加 学 号 @ 专业 码 @ 专业 码 @ 学 生 
5. @ 表 结 构 | 实 体型 的 属性 ( 列 、 字 有 段 .数据 项 ) 信 息 @ 属性 值 | 数据 行 | 数据 记录 
@ 实体 型 | 关联 | 联系 ”@ 实体 | 关联 | 联系 

6. | 学 院 码 ,学 院 名 ”@ 学 院 码 ”@ 学 院 码 , 学 院 名 

7. OXS @OMZ @XSs 

8. @ 民族 名 @ 民族 码 

9. @ (月 份 ,职工 号 ) @ 姓名 @ 基本 工资 奖金 ,个 人 所 得 税 。@ 个 人 所 得 税 
10. @ 非 主 属性 ”@ 部 分 函数 依赖 ”@ 传递 函数 依赖 

11. 3 @ 学生. 民族 和 专业 

12. @ 数据 元 余 | 数 据 重复 存储 ”@ 数据 操作 异常 | 数据 插入 、 更 新 和 删除 异常 
@ 部 分 函数 依赖 ”@ 传递 函数 依赖 

13. 非 主 属性 ”@ 部 分 @ 第 二 

14. @ 非 主 属性 @ 传递 @ 第 三 

15. @ 节省 存储 空间 @ 元 余 @ 原子 性 

16. @ 性 别 码 和 民族 码 ”@ 学 号 .专业 码 和 身份 证 号 

17. @ 职工 号 @ 性 别 、 政 治 面貌 和 职称 

18. 03 ©@®@2 1 @1 加 多 











二 、 单 选 题 

1. 也 和 四 DBE.OC 3. OC @B 4.C 5.C 
6. D 7 D 8.C 9. A 0; 炉 11. B 12. A 
I BC DC 14. B 15. C 16. D 17: B 18. B 
三 、 多 选 题 

l; CE 2. BDE 3. DADG ©@BCEFH @BEI @BE ©®@BE 
4. AE 5. BDE 6. BDF 7. ACD 8. BC 9. .AB 
10. CE 11。AC 12. BCE 13. ABD 14. BD 

15. OD EFG ©®@ ABCD 16. ADF 17. BC 18. ® ABCDEF ©® EF 
19. ABC 20. BCD 21. ACDE 22. BD 23. BD 

24. D ABCDEF ©® ABCDE ©® BCDE ©@® BCDE 

25. ABDEF 26. (DAB @EF “© DE 


四 、 数 据 库 设计 题 
1. 分 析 与 设计 如 下 。 
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【分 析 】 


由 题 意 得 知 ,每 人 每 月 发 放 一 次 工资 ,因此 ,关键 字 是 (月 份 ,职工 号 ); 姓 名、 工作 时 间 
等 部 分 函数 依赖 关键 字 ( 月 份 ,职工 号 ) ,合计 和 实 发 工资 传递 函数 依赖 关键 字 , 在 第 三 范 
式 中 要 消除 这 些 函 数 依赖 关系 。 另 外 ,考虑 所 得 税率 和 社会 保险 各 月 可 能 均 不 同 ,因此 ， 
所 得 税 和 社会 保险 不 传递 函数 依赖 关键 字 。 职 称 可 以 采用 1 位 编码 ,便于 节省 存储 空间 。 
本 题 中 涉及 职工 .工资 和 职称 3 类 实体 。 根 据 实体 型 一 表 化 的 设计 原则 ,本 数据 库 可 
由 如 下 3 个 第 三 范式 的 关系 模式 组 成 。 


【设计 】 


(1) 职工 关系 模式 。ZGB( 职 工 号 ,姓名 ,工作 时 间 , 职 称 码 , 性 别 ), 其 中 职称 码 是 外 


键 。ZGB 的 表 结 构 如 表 B-1 所 示 。 
表 B-1 职工 表 (ZGB) 结 构 




















字段 名 类 型 长 度 默认 值 
职工 号 Char 6 
姓名 VarChar 10 
工作 时 间 Date 
职称 码 Char 1 党 
性 别 Char 2 男 ' 











(2) 工资 关系 模式 。GZB( 月 份 ,职工 号 ,职务 工资 ,岗位 津贴 ,奖金 ,所 得 税 , 社 会 保 
险 ) ,其 中 职工 号 为 外 键 。 由 于 每 人 每 个 月 都 要 发 放 工资 ,所 以 GZB 关系 模式 的 关键 字 
为 : (月 份 ,职工 号 ) ,对 应 的 表 结 构 如 表 B-2 所 示 。 





























表 B-2 工资 表 (GZB) 结 构 
字段 名 类 型 长 度 默认 值 

月 份 Char 4 
职工 号 Char 6 
职务 工资 Float 9,2 0 
岗位 津贴 Float 9,2 0 
奖金 Float 9,2 0 
所 得 税 Float &2 0 
社会 保险 Float 8,2 0 


(3) 职称 关系 模式 。ZCB( 职 称 码 ,职称 ， 


字段 名 








表 B-3 职称 
类 型 





级 差 )。ZCB 的 表 结 构 如 表 B-3 所 示 。 


表 (ZCB) 结 构 
长 度 


默认 值 





职称 码 








Char 


1 
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字段 名 类 型 长 度 默认 值 
职称 Char 4 
级 差 SmallInt 4 0 





2. 分 析 与 设计 如 下 。 
【分 析 】 








本 题 中 涉及 股东 、 股 票 和 股东 账号 3 个 实体 型 ,另外 ,需要 描述 股东 与 股票 之 间 的 关 
联 , 因 此 本 数据 库 需 要 4 个 关系 模式 。 











【设计 】 
(1) 股东 关系 模式 。GDB( 身 份 证 号 ,姓名 ,联系 电话 )。GDB 的 表 结 构 如 表 B-4 
所 示 。 
表 B-4 股东 表 (GDB) 结 构 
字段 名 类 型 长 度 
身份 证 号 Char 18 
姓名 VarChar 10 
联系 电话 VarChar 20 


(2) 股票 关系 模式 。GPB( 股 票 代 码 , 股票 名 称 , 现价 )。 








GPB 的 表 结 构 如 表 B-5 














所 示 。 
表 B-5 股票 表 (GPB) 结 构 
字段 名 类 型 长 度 默认 值 
股票 代码 Char 6 
股票 名 称 VarChar 10 
现价 Float 8,2 0 











(3) 股东 账号 关系 模式 。GDZHB( 身 份 证 号 ,股东 账号 ,开户 时 间 , 资 金 余额 ), 其 中 


身份 证 号 是 外 键 ,股东 账号 为 关系 模式 的 关键 字 。GDZHB 的 表 结 构 如 表 B-6 所 示 。 
表 B-6 股东 账号 表 (GDZHB) 结 构 














字段 名 类 型 长 度 默认 值 
身份 证 号 Char 18 

股东 账号 Char 9 

开户 时 间 Date 

资金 余额 Float 11,2 0 











(4) 股东 股票 关系 模式 。 GDGPB( 股 东 账 号 ,股票 代码 , 持 有 数量 , 均 价 ) ,其 中 股东 账 
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3) 


号 和 股票 代码 分 别 是 两 个 外 键 。 由 于 一 个 股东 允许 持 有 多 只 股票 ,因此 ,GDGPB 关系 模 
式 的 关键 字 为 : (股东 账号 ,股票 代码 ) ,对 应 的 表 结 构 如 表 B-7 所 示 。 


表 B-7 股东 股票 表 (GDGPB) 结 构 

















字段 名 类 型 长 度 默认 值 
股东 账号 Char 9 
股票 代码 Char 6 
持 有 数量 Int 8 0 
均 价 Float 7,2 0 


3. 分 析 与 设计 如 下 。 


【分 析 】 


本 题 涉及 学 生 、 民 族 和 课程 3 个 实体 型 , 男 外 需要 学 生 与 课程 (成 绩 ) 之 间 的 关联 。 
股东 信息 数据 库 类 似 ,学 生 考 试 数据 库 也 需要 4 个 关系 模式 。 


【设计 】 


学 生 考试 数据 库 模式 由 如 下 4 个 关系 模式 构成 。 








XSB( 学 号 ,姓名 ,性 别 , 出 生日 期 ,民族 码 ) 
MZB( 民 族 码 ,民族 名 称 ) 
KCB( 课 程 码 ,课程 名 称 , 学 分 ) 


CJB( 学 号 ,课程 码 ,考试 成 绩 , 课 堂 成 绩 , 实 验 成 绩 , 重 修 ) 











其 中 民族 码 是 XSB 的 外 键 ,学 号 和 课程 码 是 CJB 的 两 个 外 键 。4 个 关系 模式 对 应 的 
表 结 构 如 表 B-8 至 表 B-11 所 示 。 


表 B-8 学 生 表 (XSB) 结 构 



































字段 名 类 型 长 度 典 认 值 
学 号 Char 8 
姓名 VarChar 10 
性 别 Char 1 W 
出 生日 期 Date 
民族 码 Char 2 01 
表 B-9 民族 表 ( MZB) 结 构 
字段 名 类 型 长 度 
民族 码 Char 2 
民族 名 称 VarChar 20 
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表 B-10 课程 表 (KCB) 结 构 











字段 名 类 型 长 度 默认 值 
课程 码 Char 6 
课程 名 称 VarChar 15 
学 分 TinyInt 1 1 


表 B-11 成 绩 表 (CJB) 结 构 




















字段 名 类 型 长 度 默认 值 
学 号 Char 8 
课程 码 Char 6 
考试 成 绩 TinyInt 3 0 
课堂 成 绩 TinyInt 0 
实验 成 绩 Tinylnt 3 0 
重修 TinyInt 1 0 














B.3 第 3 章 习 题解 答 


一 、 填 空 题 


1. OD Shell @ MySQL Q@root @ root © 127.0.0.1 

2. @ # @MySQL @u< 用 户 名 .hp[ 过 密码 >] @mysql> 

© Quit| Exit 

@ 标记 @ 拖 动 @ 复制 

© LocalHost ©@ % 

@ %| 其 他 计算 机 四 无 密码 @ @LocalHost 图 Identified By 'st918' 
@ Create ©@ Select 和 Alter @ Drop @ Select 和 Alter 

© Select 和 Insert © Select 和 Update ©® Select 和 Delete 

@® Create User © Select 和 Create User 

7. Ox ©@#.* ©@RCZP.* ©@ RCZP. YPRYB 

. DO:…XAMPP\MysSQL\Data ©@ :…XAMPP\MysSQL\Data\RCZP 

@ ut{f8_general_ci.ut{f8_unicode_ci, gb2312_chinese_ci, gbk_chinese_ci, utf8、 
gb2312 或 gbk。 

9. O11 ©@—128~127 @ 0~255 

10. @ 2017-9-18 9:30:10 @ 10 图 2017-9-18 9:48:20 @ 15 

iT 本 :国耻 


oO en 心 


oo 
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12. @ 内 关联 | 内 联 加 外 键 约束 关联 @ 外 键 约束 


二 、 单 选 题 

最 2 了 kN 4, CC $B 6. B 

7. D 8. B 9.C 10. D 11. B 12. D 
13.0A ®@B A @B 14. B 15. D 16. C 
三 、 多 选 题 

.GB 2 NB 3. ACD 4. ADE 5. BDE 6. CDE 
7. BD 8. AC 9.DAB ©AB @ AcC Q@ AD 

© AE © AF © AFG 10. AD 11. ABCD 12. ACE 
13. ACDE 14. BD 15. ACDF 16. AE 17,. CE 18. DE 
19. CF 20. DE 21. ACD 22. ACDF 23. ABDE 24. ABCE 


25. ACG 26. DBCEG @ADH 27. ACE 


B.4 第 4 章 习 题解 答 


一 、 填 空 题 


1. @ 数据 访问 控制 ”@ 数据 定义 ”@ 数据 操纵 ”@ 数据 查询 

2. @ Create ©@ Alter 图 Drop 

3. 3 @ 电子 商 品 ( 类 别 Char(10), 编 码 Char(6), 商 品名 称 VarChar(20)， 
Primary Key( 类 别 ,编码 )) 

4. 0 出 错 @ IfNot Exists @1 @ 匿名 @ 2017-01-08 14:03:05 @ Null 
2 @ 匿名 2017-01-08 14:03:08 @ Null 


5 D2 DZ ss5 

6. D On Duplicate Key Update ©@ Values © Set @ Replace 

和 二 和 

8. D Order By Q@ Group By © Distinct| Group By @ Having 


©® Into OutFile 

9. @ 岗位 编号 二 'B0001' 
@ 面试 成 绩 之 一 50 And 面试 成 绩 二 = 二 59| 面 试 成 绩 Between 50 And 59 
@ 面试 成 绩 二 (Select AVG( 面 试 成 绩 ) From GWCJB) 

10. @ mid( 身 份 证 号 ,17,1) % 2 二 0 | Mod(mid( 身 份 证 号 ,17,1), 2)= 二 0 
@ 姓名 Like '% 国 庆 %' | 姓名 RLike ' 国 庆 ' 
@ 通信 地 址 RLike 北京 | 上 海 | 深 圳 ' 
@ 身份 证 号 In (Select 身份 证 号 From GWCJB Where 资格 审核 ) 
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11. @ YPRYB. 身 份 证 号 二 GWCJB, 身份 证 号 四 GWB. 岗位 编号 一 GWCJB. 岗位 编号 
@ Null 
12. @ Null @10 ©® [NotjIn\All.Any | Some、 [Not] Exists 
13. @ Natural Join @ Natural Join @ 面试 成 绩 这 四 AVG( 面 试 成 绩 ) 
@ CJB. 岗位 编号 二 GWCJB. 岗位 编号 
14. g@ 骨 套 、 合 并 @ Select\Update 和 Delete @ Select 和 Update @ Select 
15. @ Create Table Insert\、Replace 或 Select @ Union All @ Union @ 地 址 


二 、 单 选 题 


1. B pe 3.B Fa] 5.OB @D 

OA OB OD OC @F 7. DB @C 8.DE @F 
9. A 1 BD 6 12. A 13.C 14.B 15.A 

16. B vs 18. D 19. B 20.B 21.B 22.D 

三 、 多 选 题 


1. ADE 2. CE 3. CDEF 4. BCE 5. DBCDI ©® EFGHI] ©® AK 
6.D0DAG @AH @A @ABE @OAE @AL OEIl 

7. OO AB ©® BCDE 8. BCDE 9. BCDE 10. OBC ©@BC 11. BE 
12. ABDFG 13. ABCEHJ 14. ACDEFH ©®@ EH ©® ACDF 15. BDFG 
16. OAC ©®@ ACD 17. © ABFGH ©® EH 18. OD BCE ©® ABC 

19. AEG 20. ABE 21. BH 22. BCD 23. ABCEG 24. CDE 

25. ADE 26. DBCEH ©®@DF 27. BDEF ©® ABCDEF 

28. BCE 29. BC 


四 、SQL 语句 填空 题 


1. @ Count( 岗 位 编号 )|Count(*) @ Natural Join @GroupBy @ Having 
@ 岗位 数 DESC|3 DESC 

2. View|Table @ Min( 笔 试 成 绩 ) ”@ Group By @ 笔试 成 绩 @ 最 低 分 
©@ View|Table 

3，@ Count( 身 份 证 号 )|Count( x*) ”@ GWB. 岗位 编号 二 GWCJB. 岗位 编号 
@ In @ 岗位 编号 @ Order By @ DESC 


五 、SQL 语句 输出 结果 填空 题 


05 ®@3 @7 @5 

.O06 D1 ON Oo0 95 ©O3 O79 
06@o@Nul @o0 

.O85 ®@68 @84 @80 0 @Nul 
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六 、SQL 语句 设计 题 


1. 分 析 与 设计 如 下 。 

【分 析 】 

本 题 要 求 将 GWCJB 中 每 个 岗位 的 统计 结果 一 一 笔试 平均 分 再 添加 到 本 表 中 ,首先 
应 该 考虑 用 嵌 套 的 SQL 语句 进行 设计 。 在 向 GWCJB 中 增加 字段 后 ,似乎 用 一 条 组 套 语 
句 Update GWCJB Set 岗位 平均 笔试 分 = (Select AVG(' 笔 试 成 绩 ') From GWCJB As 
CJB Where GWCJB. 岗位 编号 二 CJB. 岗位 编号 ) 就 能 解决 问题 ,但 是 ,语句 中 被 修改 的 表 
与 子 查 询 的 数据 源 同 是 GWCJB, 违 背 MySQL 的 有 关 规 定 , 不 能 运行 。 

解决 这 个 问题 有 两 个 途径 : 一 是 应 用 视图 对 象 ,二 是 借用 备份 表 。 

【设计 】 


Alter Table GWCJB Add 岗位 平均 笔试 分 Int /x* 增加 字段 * /; 


Create View PJF As Select 岗位 编号 ,AVG (笔试 成 绩 ) As 岗位 平均 笔试 分 
From GWCJB Group By 岗位 编号 /* 创建 视图 PJF* /; 


Update GWCJB SET 岗位 平均 笔试 分 = /=* 嵌 套 SQL 语句 ,视图 PJF 为 子 查询 数据 源 * / 
(Select 岗位 平均 笔试 分 From PJF Where GWCJB. 岗 位 编号 =PJF. 岗 位 编号 ) ; 


Drop ViewPJF /* 删除 不 再 使 用 的 视图 PIF* /; 


只 要 将 上 述 SQL 语句 中 的 Create View 改 成 Create Table, Drop View 改 为 Drop 
Table, 就 换 成 了 备份 表 的 设计 方法 ,也 可 以 满足 问题 的 设计 要 求 。 

2. 分 析 与 设计 如 下 。 

【分 析 】 

由 于 本 题 要 求 输出 GWB 中 的 全 部 岗位 ,包含 没 人 申报 的 岗位 ,因此 ,用 GWB 与 
GWCJB 进行 内 连接 或 自然 连接 都 不 能 满足 要 求 。 

解决 此 类 问题 时 ,一般 考虑 用 表 之 间 左 连接 加 分 组 或 嵌 套 的 SQL 语句 进行 设计 。 


【设计 】 
Select GWB. 岗 位 编号 ,岗位 名 称 ,， 人 数 ， /* 设 计 一 : 表 之 间 左 连接 加 分 组 * / 
Count (身份 证 号 ) as 申报 人 数 ， /x 不 能 用 count (x )x*/ 


IfNu11 (Max (笔试 成 绩 ) ,0) as 笔试 最 高 分 
From GWB Left Join GWCJB On GWB. 岗 位 编号 =GWCJB. 岗 位 编号 
Group By GWB. 岗 位 编号 ; 


Select 岗位 编号 ,岗位 名 称 ， 人数， /* 设计 二 : 嵌 套 的 So 语句 * / 
(Select Count (* ) From GWCJB Where GWB. 岗 位 编号 =GWCJB .岗位 编号 ) As 申报 人 数 ， 
IfNull((Select Max (笔试 成 绩 ) From GWCJB Where GWB. 岗 位 编号 =GWwCJB. 岗 位 编号 ) , 0) 
As 笔试 最 高 分 


From GWB; 
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3. 分 析 与 设计 如 下 。 

【分 析 】 

将 表 中 的 一 个 记录 分 成 几 个 记录 存储 ,实质 是 两 个 问题 : 其 一 是 两 个 Select 语句 的 
合并 问题 ,其 二 是 Create Table 与 Select 语句 的 再 合并 问题 。 


【设计 】 

Create Table BSMS As /* Create Table 与 合并 后 的 Select 语句 青 合并 * / 
Select 岗位 编号 ,身份 证 号 , ' 笔 试 ' as 考试 形式 ,笔试 成 绩 as 成 绩 From GWCJB 

Union /* 两 个 Select 语句 合并 * / 


Select 岗位 编号 ,身份 证 号 , ' 面 试 ' ,面试 成 绩 From GWCJB 
order By 岗位 编号 ,身份 证 号 ; 


4. 分 析 与 设计 如 下 。 
【分 析 】 
首先 需要 创建 一 个 视图 GV ,包括 每 人 的 身份 证 号 、 笔 试 平 均 分 和 笔试 最 高 分 , 青 用 
GV.、GWB、YPRYB 和 GWCJB 通过 内 连接 或 自然 连接 及 查询 租 套 解决 两 个 设计 问题 。 
【设计 】 
Create View GV Rs Select 身份 证 号 ,AVG (笔试 成 绩 ) As 笔试 平均 分 ,/ * 创建 视图 GV* / 
Max (笔试 成 绩 ) As 笔试 最 高 分 From GWCJB Group By 身份 证 号 ; 


Select 身份 证 号 ,姓名 ,岗位 名 称 , 笔 试 成 绩 
From GWB Natural Join GWCJB Natural Join YPRYB Natural Join GV 
Where 笔试 成 绩 > 笔 试 平 均 分 /* 利用 视图 GV 输出 高 于 平均 分 的 岗位 * /; 


Select 身份 证 号 ,姓名 ,岗位 名 称 ,笔试 成 绩 
From GWB Natural Join GWCJB Natural Join YPRYB Natural Join GV 


Where 笔试 成 绩 = 笔 试 最 高 分 /* 利用 视图 GV 输出 等 于 笔试 最 高 分 的 岗位 * /; 


如 果 将 视图 作为 子 查询 的 数据 源 , 也 可 以 实现 本 题 要 求 。 请 读者 尝试 修改 上 述 设 计 ， 
用 嵌 套 的 设计 方法 满足 本 题 要 求 。 


B.5 第 5 章 习 题解 答 


一 、 填 空 题 


@ 一 组 SQL 语句 @ 触发 器 加 事件 @ 存储 过 程 @ 存储 函数 
. OO Begin @ End @ 多 条 

. DDeclare Q@ 类 型 @ 默认 值 

. Set @ 定义 它 的 过 程 体 中 @@ 

. @ 变量 @ into 天 变量 名 表 > @1 

. @ 游标 @ 纪录 集 @@ 存储 过 程 @ 存储 函数 


wD 
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7. 


8. 


@ Declare @ Open 志 游 标 名 称 二 ”图 Fetch…into 


@ Close 二 游标 名 称 二 


Dif © Case 四 While @ Repeat © Loop 
9. 有 序 SQL 语句 的 集合 ”四 数据 库 


. @ Call @ 实际 参数 
.OIn ©@Out @InOut @ Returns 
. @ 数据 表 @@Update 
. @ Create Trigger @ Before @ After @ 数据 表 @ 临时 表 @ 视图 
. © Show Triggers ©@ Drop Trigger 

. @ 特定 时 间 周 期 四 


Ol @my.ini 


二 、 单 选 题 


1. 
x 


13. 


D 2.C 
B 8.C 
C 14. D 


三 、 多 选 题 


l; 
家 


Ll; 
2. 
3. 
4. 


1 
2 
3. 
4 


ACDE 2. ABE 
ABC 8. ABE 


、 程序 填 空 题 


@ 实 参 @ 形 参 


@lInsert @ Delete 


事件 调度 器 @Event_Scheduler @True 


4.C 5.B 6.D 
和 已 10. D 1 如 12. D 
3. BE 4. AF 5. ACD 6. BCE 


9. ABCE 10. BDE 11. ABE 12. ABDF 


QO Delimiter © Procedure © Update 
Q@ Function @ Returns Int @ 姓名 =xm 


© Trigger © After 


@ For Each Row 四 @countrs 十 1 


QO On Schedule ©@ Starts @ Do 


B.6 第 6 章 习 题解 答 


、 填空 题 
超 文 本 标记 语言 


首选 参数 


-加 文字 四 图 片 @ 超 链接 @ 超 链接 


. -工作 模式 下 拉 框 ”@ 菜单 栏 @ 文档 工具 栏 ”@ 文档 窗口 ”@ 状态 栏 


@ 属性 面板 @ 浮动 面板 组 
5. @ 站 点 @ 本 地 @ 服务 器 (远程 ) 
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6. @ 对 标签 ”四 单 标 签 ”@ 起 始 标 签 ”@ 结束 标签 
7. 起 始 

8. @ <Head> ©®@ <Title> 加 二 Body> 

9. 四 Bgcolor; ©®@ BackGround; @ Text 

10. © <Enter> Q@ <P>:…</P> 

i D> 国志 @<U> < 

12. <IMG> 

13. 图 像 超 链接 

14. QO 标记 选择 器 ”@ 类 选择 器 @ ID 选择 器 


15. @ 圆 点 <.” 四 “#* 号 
二 、 单 选 题 

| We 9 2 Fe 4. D 5 路 6. D 
7.D 8..DC @OD 人 了 9.A 10. D 1 起 
12. BD 13. QD @A QC 14. A 15;: 野 

三 ,多 选 题 

1. ADE 2. ACDEF 3. BCD 4. BC 5. BEF 6. BCD 
7. ACE 8. CE 9. AE 10. BCF 


B.7 第 7 章 习 题解 答 


一 、 填 空 题 


1. @ 左 侧 栏 四 脚注 区 @ 左 侧 栏 
2. th @td @ 像素 
3. @ 框架 集 文件 @ frameset @ frame 
4. 四 块 @ 内 联 

5. get ©@ post @@ post 
6. Dinput © password @ size 

7. @ 构件 结构 @ JavaScript @ CSS 

8. @ 模糊 @ 有 效 

9. © submit Q@ value 

10. | 可 编辑 区 域 @ 重复 区 域 @ 可 选区 域 


二 、 单 选 题 


二 -到 2.B 3.C 4. A 5.A 6. B 
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三 、 多 选 题 
1 ABLC 2. ABCF 3. ABCD 4. ACD 5. ADE 6. BD 
7. BCDE 8. CE 9. CD 10. AC 


四 、 程 序 填空 题 


1.@ method © password © submit 
2. OD# ©@float ©®@left @ answer 


五 、 程 序 运行 结果 填空 题 


1. 4 加 3 @ 3px @Web 程序 设计 
2. D3 @Send.html @80 @30 


1. 分 析 与 设计 
【分 析 】 
常见 的 “ 厂 字 型 "布局 页 面 是 指 :页 面 顶 部 为 横 条 网 站 标识 ,下 方 左 侧 为 主 菜单 , 右 侧 
为 网 站 正文 的 布局 。 使 用 Div 十 CSS 设计 “ 厂 字 型 "布局 时 ,可 以 通过 “Id” 为 “container” 
“header”“menu” 和 “content” 的 Div 标签 分 别 实现 网 页 的 整体 框架 区 、 网 站 标识 区 .菜单 
区 和 正文 区 ,并 使 用 CSS 为 不 同 区 域 设计 布局 样式 。 
【设计 】 
<html><head> 
<style type="text/css"> 
div#container{width:500px} 
div#header {background- color:#99bbbb;} 
div# menu {background- color: # ffff99; height: 200px; width: 150px; float: 
left;} 
div#content {background- color:#EEEEEE;height:200px;width:350px;float: 
left;} 
</style></head> 
<body> 
<div id="container"> 
<div id="header"><h1> 网 站 标识 </h1>< /div> 
<div id="menu"> 
<h2> 菜 单列 表 < /h2> 
<ul><1li><ahref="# "> 菜单 1</a></1i> 
<1i><a href="#"> 菜 单 2</a></1i> 
<1i><a href="#"> 菜 单 3</a></1i></ul></div> 
<div id="content"> 网 页 正文 </div> 
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2. 


</div></body></html> 


分 析 与 设计 


【分 析 】 

“三 字 型 "布局 的 特点 是 在 页 面 上 有 横向 两 条 色 块 ,将 页 面 分 割 为 三 部 分 ,顶部 为 网 站 
标识 ,中间 为 网 站 正文 ,底部 为 网 页 说 明 。 使 用 框架 设计 “三 字 型 "布局 时 ,需要 设计 四 个 
网 页 ,包括 :框架 集 页 面 “main. htm”、 顶 部 页 面 *header. htm”\ 正 文 页 面 “body. htm” 和 底 
部 页 面 “footer. htm”。 

【设计 】 

main. htm 代码 : 


<html> 


<frameset rows="25% ,50% ,25% "> 
<frame src="header.html"> 
<frame src="body.html"> 
<frame src="footer.html"> 

</frameset></html> 


header. htm 代码 ; 


<html><body bgcolor= "#99bbbb"> 


<hl align="center"> 网 站 标识 </h1l></body></html> 


body. htm 代码 : 


<html><body bgcolor="#EEEEEE"> 


<h3> 网 页 正文 </h3></body></html> 


footer. htm 代码 : 


<html><body bgcolor="#99bbbb"> 


2 


<h3 align="center"> 网 页 说 明 </h3></body></html> 


B.8 第 8 章 习 题解 答 


、 填 空 题 


. @ 新 建 ”@ 新 建文 档 @ PHP 

. 代码 @ 实时 视图 @ 在 浏览 器 中 预览 /调试 

.Ds @ 字 母 @ 汉字 @ 数字 @ 下 面 线 

. @ Web 服务 器 @<?PHP 四 天? @<”% @?> ©@%> 

. 分 号 (;) @ 函数 名 称 @ 类 名 称 图 关键 字 @ 半角 

.上 上方 @ 尾 部 @ /x Q@x*/ @// @@ 间 

.四 常量 @ 变量 @ 函数 名 @ 运算 符 @ 字符 串 @ 数值 @ 括号 
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8. @ 单 引 号 () @ 双 引 号 (") @ 界定 符 (<<<) 
9. 半角 句号 (.) 
10. OLtrim @Rtrim @Trim @Strlen @3 @Strcmp 0 
11. 0 @0x 加 直接 书写 @ 科学 计数 
12. © Abs Q@ Round Q@Sqrt @ Pow 或 Pow(3,4) 
13. OO Getdate © Strtotime © Date_Default_Timezone Set @ "PRC" 
14. @ 逻辑 与 ”@ 逻辑 或 ”、@ 逻辑 异 或 ”、@ 逻辑 非 
15. @ 字符 串 @/ @ 普通 字符 ”@ 特殊 字符 ”@ 匹配 
16. Q@ 单个 字符 ”@ 模式 单元 @ 普通 字符 表 ”@ 普通 转 义 字 符 ”@ 原子 表 
@ 重复 匹配 @ 边界 限制 @ 特殊 字符 “.” @ 模式 单元 @@ 模式 选择 符 
二 、 单 选 题 
本 :1 2. A 3.C 4.C 5.B 6.D 7. A 
8.D 9 10. C 有 12. B 13. D 14. D 
15. A 16. B 17. C 18. C 19. D 20. D 
三 、 多 选 题 
1. ABCDE 2. AC 3. ACE 4. ABCE 5. BDE 
6. BEF TAC 8. BCD 9. ABE 10. BDE 
11. BCDF 12. BCD 13. AC 14. BE 
B.9 第 9 章 习 题解 答 
一 、 填空 题 
1. © if …elseif…else… © switch case @if @ else 
2. | 循环 体 ”@ 不 成 立 
3. 完全 
4. foreach 
5. © break © continue 
6. @ 不 相同 ”四 多 维 数 组 
7. @ 逻辑 型 ”@ 下 标 / 键 值 
8. QO implode() © explode() 
9. @ 用 户 自 定义 ”@ 内 置 /系统 
10; 一 


11. @ 值 加 引用 @ 引 用 
12. @ 默认 参数 @ 后 
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13. Global 
14. @ 被 保留 ”@ Static 
15. Q@ 两 个 @ Error Level 图 Error Message 
16. Png 
17. @ Post ©@ Get 图 Method 
18. @ $_POSTL] @ $_GET[ ] @ name 
19. Di# © IsSet() 
20. 要 调用 的 PHP 文件 
21. @ Value @ 循环 
22. Multipart/Form-Data 
23. @ 1 四 选 定 文件 的 绝对 存储 路 径 
24. 二 @ 文 件 域 控件 名 @Name @ Type 
© Tmp_Name © Error 
二 、 单 选 题 
D 3 C 和 B 
a CC 9. D 
三 、 多 选 题 
1. ACE 2. ACE 3 BD 4. ACDE 
7. BCD 8. ABDE 9. AD 10. BCE 
四 、 程 序 填空 题 
1. O100 ©@ $n++ ©@ continue 
2.0 Array © $i== $j] ©@ $i+$j==2 
3. OlIsSet() @ $x ©®@ $x%10 
4. © $i<5 ©® $a[$i]>$a[$j] @ $a[$i 
5. @ Static ©@ $it+ ©@ Fac( $i) 
6. D Count ©® $i ©@ Break 
7. O00 @Tmp Name @ Type 
五 、 程 序 结果 题 
人 人 3 
2. O11 ©@18 @26 
3. @ 46 
4. D1 @1l @1139 
5.@10 ©@16 @16 
6. D1 @1990-09-11 @ 学 士 








© Size 


5. ABD 6. BD 
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1. 分 析 与 设计 如 下 。 
【分 析 】 
首先 通过 一 个 循环 来 表示 100 到 999 之 间 的 全 部 整数 ,然后 对 每 个 分 别 做 除 10 求 余 
运算 得 到 其 个 位 数 部 分 ,再 对 其 除 10 后 做 除 10 求 余 运算 得 到 其 十 位 数 部 分 ,再 次 对 其 除 
以 100 并 取 其 整数 部 分 ,得 到 它 的 百 位 部 分 ,最 后 判断 个 位 十 位 百 位 数 的 立方 和 是 否 与 原 
数 相等 ,如 相等 则 是 水 仙 花 数 。 
【设计 】 
<?PHP 
For ($i=100;$i<=999;$i++) 
{ $a=$i%10; 
$b= ($i/10)$%10; 
$c=floor ($i/100); // 取 $i/100 的 整数 部 分 
IE ($i==$ax Sax $at$bx $bx $bt$cx* $cx$c) 
{ Echo $i; 
Echo "</br>";} 


元 


2. 分 析 与 设计 如 下 。 
【分 析 】 
利用 else…if 结构 ,针对 每 种 情况 设置 一 个 选择 分 支 , 根 据 分 支 选 择 的 情况 输出 相应 
的 等 级 。 
【设计 】 
<body> 
<form id="forml" name="forml" method="post" action=""> 
<label for="textfield"></label> 
<input type="text" name="sz" /> 
<input type="submit" name="tj" value=" 提 交 " /> 
</form> 
去 全 下 政和 
if(isset($ POST["tj"])) 
{ $i=($_POST["sz"]); 
If ($i>=90) 
echo "A"; 
ElseIf ($i>80) 
echo "B"; 
ElseIf ($i>70) 
echo "C"; 
ElseIf ($i>60) 


echo "D"; 
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</body> 


3. 分 析 和 设计 如 下 。 
【分 析 】 
根据 数学 中 的 定义 ,最 小 公 倍 数 一 两 整数 的 乘积 二 最 大 公约 数 , 求 最 大 公约 数 可 以 用 
轧 转 相 除 法 ,有 两 整数 $a 和 $b:@` $a% $b 得 余数 $c @ 若 $ c= 二 0, 则 $b 即 为 两 数 
的 最 大 公约 数 @ 车 $c 关 0, 则 $a 二 $b, $b 二 $c, 再 回去 执行 
【设计 】 
<body> 
<form id="forml" name="forml" method="post" action=""> 
<label for="textfield"></label> 
<input type="text" name="szl1" id="textfield" /> 
<label for="textfield2"></label> 
<input type="text" name="sz2" id="textfield2" /> 
<input type="submit" name="tj" id="button" value= "提交" /> 
</form> 
<?PHP 
if(isset($ POST["tj"])) 
{ $i=($_POST["sz1"]); 
$j= ($_POST["sz2"]); 
$a=$i; 
$b=$j; 
$c=floor ($as$b); 
While ($c!=0) 
{ $a=$b; 
$b=$c; 
$c=floor ($as$b);} 
$d=$ix*$j/$b; 
Echo "最 大 公约 数 是 : $b"; 
Echo "最 小 公 倍数 是 : $d";} 
?></body> 


4. 分 析 和 设计 如 下 。 

【分 析 】 

对 于 一 个 正 整 数 ,我 们 可 以 利用 2 到 这 个 数 的 算术 平方 根 之 间 的 所 有 整数 去 除 这 个 
数 , 如 果 其 中 某 个 数 能 将 其 整除 ,说 明 它 不 是 一 个 素数 ,如 果 这 个 范围 内 的 数 都 不 能 将 之 
整除 ,说 明 它 是 一 个 素数 。 

【设计 】 

<body> 
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<form id="forml" name="forml" method="post" action=""> 
<label for="textfield"></label> 
<label for="textfield2"></label> 
<input type="text" name="sz" id="textfield2" /> 
<input type="submit" name="tj" id="button" value= "提交 " /> 
</form> 
<?PHP 
Function sushu($a) 
{ $f=0; 
For ($i=2;$i<Floor(Sqrt ($a));$i++) 
{ If($ass$i==0) 
{ $f=1l;break;} 
} 
if($f==1) 
return 0; 


return 1; 


if(isset($ POST["tj"])) 
{ $s= $_POST["sz"]; 
if (sushu($s)==1) 
echo "$s 是 一 个 素数 "; 
else 
echo "$s 不 是 一 个 素数 "; 
}12> 


</body> 


B.10 第 10 章 习题 解答 


一 、 填 空 题 


@ 站 点 四 文档 类 型 @) 测试 服务 器 团 记录 集 

Q@ Connections ©@ PHP 

QO MySQL _ Connect/MySQL Pconnect 加 MySQL Close 
@ Set Names 字 符 集 ' 

J@ 记录 集 @ 数据 库 查 询 

OO 绑 定 @ 十 加 记录 集 (查询 ) 

Q@ HTML 表单 ”@ “插入 记录 ?服务 器 行为 

四 $ GET 回 $_ POST 

Q@ MySQL Query @ 服务 器 


oT 人 wr 
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本 2 三 4. B 5. 四 6.A 
7 BB 2. 

三 、 多 选 题 

1. AB 2. BE 3 CDE 4. AD 5. CD 


四 、 程 序 填空 题 


1. © RCZP.PHP © rczp ©@ MySQL_Pconnect 
2. @ Connections @ $_GET @ $mec 
3. @ 笔试 十 面试 @ while @ 总 分 


五 ,程序 结果 题 
1. @ 数据 库 @ 高 数 @ 外 语 


B.11 第 11 章 习题 解答 


一 、 填 空 题 


1. @ 会 话 2. @ 维护 ”@ 会 话机 制 3. @ 无 状态 

4. @ Cookie @ Session 5. @ 头 部 6. @ 客户 端 

7. @ 服务 器 端 8. @ 注销 9. @ 内 存 10. SetCookie @ 变量 名 
11. @ 程序 @ 系统 自动 12. 1 13. @ Session_Start 

14. DOD Unset 15. @ Session_Destroy 


二 、 单 选 题 

kB 2 3. B 4 C 6 6 
LB 8.B 9. A 10. D 

三 、 多 选 题 

了 2. CE 3 BCD 4. BC CE 6. DE 
7 BE 8. ABE 9. BD 10. ADE 
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B.12 第 12 章 习题 解答 


一 、 填空 题 


1. 移动 互联 网 

2. 手机 

3. OD WAP @ HTML5 
4. XHTML MP 

5. 子 集 

6. 2014 

7. @ 对 角 线 四 英寸 
8. @ 物理 像素 @ PX 
10. 英寸 @ 像素 
11. 逻辑 像素 

12. border-radius 


13. 外 部 阴影 

二 、 单 选 题 

il: B 2. B 4. 4. B SC 6. A 

8 CG 9. A 10. B 1 DBD 12. A 
13,. CC 

三 、 多 选 题 

1. ACDE 2. ABCDEF 3. ABCDE 4. BD 5. ABC 6. ABCD 
7. ABDEF $8. BCDE 9. AD 10. BE 二 ED 12. AB 


B.13 第 13 章 习题 解答 


一 、 填空 题 
1. Session 

2. 首页 

3. Frame/ 框 架 
4. 导航 

5. B/S 


(a8) 基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


6. Connections 

7. 域名 

8. 一 对 一 

9. OGET ©® POST 


10. @ 英文 字母 ”@ 数字 @ 半角 的 连接 符 “ 一 ” 


5.B 6.C 
11. A 12. A 
5. BDEF 6. ABCDE 


二 、 单 选 题 

1. A 2. A 3. A 4. B 

7. A 8. A 9. A 10. A 

13. B 1 和 ,已 15; BD 

三 、 多 选 题 

1. ABC 2. AB 3 .ABCD 4. ABCDF 
7. ABE 8. ABCE 9. BCEF 10. ABCD 
、 程序 填空 题 

1. DO Method Q@ Action © /Form 

2. 0 $ MySQL © RCZP @ MySQL Query 

3. D Name ©@ Submit @ Value 

4. D Require ©@ $SQL ©@ $ Result 

5. DO Rows ©@ Cols ©@ </Framset> 

6. D Order By ©@ $MySQL Query ©® $ Result->Free() 


五 、 程序 设计 题 
1. 分 析 与 设计 


<?PHP 


$MySQL =New MySQL('LocalHost', 'Root','123', 'RCZP'); 


// 连 接 RCZP 数据 库 , 用 户 名 为 Root 、 密 码 为 123 
MySQL Query ($MySQL, "Set Names 'UTF8"'"); 


2. 分 析 与 设计 


<Html><Body> 


<Form Name="Form" Method="Post" Action=""> 


<P> 管 理 员 登录 < /P> 


<P> 账 号 :<Input Type="Text" Name="Name"/></P> 


<P> 密 码 :<Input Type="Password" Name="Password" /></P> 
<P><Input Type="Submit" Name="D1" Value=" 确 认 "/></P> 


</Form></Body></Html> 


附录 B 主教 材 习题 解答 9) 


3. 分 析 与 设计 





属性 值 如 表 B-12 所 示 。 














表 B-12 属性 值 
作用 HTML 标签 Name\ID Type 类 型 Value 初始 值 
标题 Biaoti Text 空 
<? PHP 
<Input/> Date_Default_Timezone_Set 
隐藏 域 Shijian Hidden (CAsia/Shanghai) ; 
Echo Date("Y-m-d"); 
?7> 
=Textarea> 
容 i 六 
内 容 ea Neirong Textarea 空 
修改 一 Input /> Submit Submit 修改 





4. 分 析 与 设计 


<HTML><Head> 
<Meta HTTP- Equiv="Content-Type" Content="Text/HTML; Charset=UTF-8" /> 
<Title> 程 序 题 3< /Title>< /Head> 
<Frameset Rows="105, x " Cols="*" ><!-- 定 义 框架 开始 --> 
<Frame Src="Top .PHP" Name=" 顶 区 " Scrolling="No"/> 

<!-- 定 义 顶 区 框架 链接 的 源 文件 为 Top.PHP 滚动 条 属性 值 为 No --> 


<Frameset Rows ="*" Cols="]113, *"> 


</Frameset><!-- 定 义 框架 结束 --> 











<Frame Src="Left .HTML" Name=" 左 区 " Scrolling="No"Noresize /> 


<!-- 定 义 左 区 链接 的 源 文件 为 Left .HTML- -> 


<Frame Src="Jieshao.HTML" Name=" 浏 览 区 " Scrolling="Yes" Noresize /> 


<!-- 定 义 浏览 区 链接 的 源 文件 为 Jieshao.HTML- -> 


</Frameset> 


</HTML> 
5. 分 析 与 设计 


Select * From 论坛 Where 文章 主题 Like '$ 吉 林 大 学 %$' Or 内 容 Like '$ 人 才 $' 
Order By 文章 序号 


B.14 第 14 章 习题 解答 


一 、 填空 题 


1. @ 动态 网 站 ”@ 内 容 管理 系统 


的 0) ”基于 互联 网 的 数据 库 及 程序 设计 实践 指导 与 习题 解答 (第 2 版 ) 


Q@ YPRYB @ 身份 证 号 
©@ TemplateEndEditable 


D 4. 


2. @ MD5 

3. 中 RCZP. php © Connections 
4. @ 公司 表 四 公司 名 称 

5.@D TemplateBeginEditable 

6. 中 Header ©@ Location 

7. 中 Natural Join @ Order by 
8. DO Mysql_query © Session_Start 
二 、 单 选 题 

1; 已 2.D 3 
生生 8 

三 、 多 选 题 

1. BDF 2 CD 3. 


ABD 4. ADF 


“WD 6. 


Cn 
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D] 
[2] 
E31 
[4 
[5] 
[6] 
[7] 
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